Android 下 JNI 开发Day2

06_Android.mk详细介绍-10

# $是调用编译工具链中的函数, 这里的作用是获取当前文件目录.

LOCAL_PATH := $(call my-dir)

# 清空并初始化编译工具链的变量.

# 注意: 会清空所有的LOCAL_变量, 但不会清空LOCAL_PATH的变量.

include $(CLEAR_VARS)

# 编译出来文件的名字, 编译系统会在名字前加lib前缀. 如果已经写lib, 不会再添加.

# 注意: 不可以加扩展名.

LOCAL_MODULE    := atguigu

# 指定编译的源文件.如果多个源文件可以用空格连接起来

LOCAL_SRC_FILES := hello.c

# 指定编译文件类型

# 动态库(BUILD_SHARED_LIBRARY) 扩展名:.so 体积小.

# 静态库(BUILD_STATIC_LIBRARY) 扩展名:.a  体积大.

include $(BUILD_SHARED_LIBRARY)

Android.mk 的含义

LOCAL_PATH:=$(call my-dir)

LOCAL_PATH是定义源文件在哪个目录用的.

my-dir 是个定义的宏方法, $(call my-dir)就是调用这个叫 my-dir的宏方法,这个方法返回值就是

Android.mk文件所在的目录

include $(CLEAR_VARS)

CLEAR_BARS 变量是build system里面的一个变量

这个变量指向了所有的类似 LOCAL_XXX的变量,

执行完这一句话, 这个编译系统就把 所有的类似

LOCAL_MODULE,_SRC_FILELOCALS,LOCAL_STATIC_LIBRARIES,...这样的变量都清除掉

但是不会清除掉 LOCAL_PATH

LOCAL_MODULE  就是你要生成的库的名字,名字要是唯一的这个.不能有空格.

编译后系统会自动在前面加上lib的头, 比如说我们的Hello 就编译成了libHello.so

还有个特点就是如果你起名叫libHello 编译后ndk就不会给你的module名字前加上lib了

但是你最后调用的时候 还是调用Hello这个库

LOCAL_SRC_FILES = :Hello.c

这个是指定你要编译哪些文件

不需要指定头文件 ,引用哪些依赖, 因为编译器会自动找到这些依赖 自动编译

include $(BUILD_SHARED_LIBRARY)  BUILD_STATIC_LIBRARY

.so

编译后生成的库的类型,如果是静态库.a 配置include $(BUILD_STATIC_LIBRARY)

别的参数

LOCAL_CPP_EXTENSION := cc //指定c++文件的扩展名

LOCAL_MODULE    := ndkfoo

LOCAL_SRC_FILES := ndkfoo.cc

LOCAL_LDLIBS += -llog -lvmsagent -lmpnet -lmpxml -lH264Android

//指定需要加载一些别的什么库.