闲谈:Android源码是在Linux系统下来发的,里面涉及到的编译系统,如上图,图一的目录下有Makefile 脚本,执行图二的build文件夹内容,具体编译过程可参考:https://www.cnblogs.com/shakin/p/4615872.html连续的几篇博客
Android.mk文件:轻量级的makefile文件(makefile定义一些指令,类似脚本文件,指定文件的编译顺序)
作用:告知NDK,Build系统关于Source的信息,android.mk是编译器makefile的一部分,会被build system解析一次或者多次,因此,尽量少的在android.mk文件中声明变量,也不要声明不会解析的定义
Android.mk
每个Android.mk文件中都会有如下两行
1:LOCAL_PATH:= $(call my-dir)
作用:将LOCAL_PATH变量定义后,表示当前的文件路径
2:include $(CLEAR_VARS)
作用:清理编译环境中的变量
Android.mk中其他的一些环境变量配置:
变量名 | 意义 |
---|---|
LOCAL_MODULE | LOCAL_MODULE变量必须定义,以标识你在Android.mk文件中描述的每个模块。名称必须是唯一的,而且不包含任何空格。注意编译系统会自动产生合适的前缀和后缀,换句话说,一个被命名为'foo'的共享库模块,将会生成'libfoo.so'文件。 |
LOCAL_SRC_FILES | 当前模块包含的所有源码文件, 我们可以这么写LOCAL_SRC_FILES := $(call all-subdir-java-files) |
LOCAL_MODULE_TAGS | 当前模块所包含的标签,一个模块可以包含多个标签。标签的值可能是 debug, eng, user,development 或者 optional。其中,optional 是默认标签。标签是提供给编译类型使用的。不同的编译类型会安装包含不同标签的模块,建议写成LOCAL_MODULE_TAGS := optional |
LOCAL_STATIC_JAVA_LIBRARIES | 当前模块依赖的Java静态库,所谓静态库,即编译完会存在于你的module里面,成为其一部分 |
LOCAL_SHARED_LIBRARIES | 当前模块在运行时依赖的动态库名, 即编译完不会存在于你的module里面 |
LOCAL_CERTIFICATE | 签署当前应用的证书名称,比如platform, 如下LOCAL_CERTIFICATE := platforms |
LOCAL_SHARED_LIBRARIE | 当前模块在运行时依赖的动态库名 |
LOCAL_PRELINK_MODULE | 是否需要预连接处理(默认需要,用来做动态库优化) |
LOCAL_REQUIRED_MODULES | 指定模块运行所依赖的模块(模块安装时将会同步安装它所依赖的模块) |
LOCAL_PROGUARD_ENABLED | enabled或者disabled 指定是否启动混淆 |
LOCAL_PROGUARD_FLAG_FILES | 指定混淆配置 proguard.config |
LOCAL_PACKAGE_NAM | 当前 APK 应用的名称。 |
LOCAL_CFLAGS | 提供给 C/C++ 编译器的额外编译参数, 比如指定所有warning成error, 指定优化等级这些, 比如: LOCAL_CFLAGS := -Werror |
LOCAL_C_INCLUDES | C/C++所需的头文件路径,比如:LOCAL_C_INCLUDES += $(JNI_H_INCLUDE) \ $(LOCAL_PATH) \ system/core/include \ frameworks/base/include \ libnativehelper/include \ |
LOCAL_JAVA_LIBRARIES | 编译java应用程序和库的时候指定包含的java类库,目前有core和framework两种, 多数情况下定义成LOCAL_JAVA_LIBRARIES := core framework 注意LOCAL_JAVA_LIBRARIES不是必须的,而且编译APK时不允许定义(系统会自动添加) |
LOCAL_REQUIRED_MODULES | 指定模块运行所依赖的模块(模块安装时将会同步安装它所依赖的模块) |
LOCAL_PREBUILT_LIBS | 需要预编译的lib, 类似PREBUILT的还有很多,比如LOCAL_PREBUILT_JAVA_LIBRARIES, LOCAL_PREBUILT_STATIC_JAVA_LIBRARIES |
include $(BUILD_STATIC_LIBRARY) | 表示编译成静态库 |
include $(BUILD_SHARED_LIBRARY) | 表示编译成动态库。 |
include $(BUILD_EXECUTABLE) | 表示编译成可执行程序 |
include $(BUILD_PACKAGE) | 编译成APK |
include $(BUILD_STATIC_JAVA_LIBRARY) | 编译成Java静态库 |
include $(BUILD_MULTI_PREBUILT) | 其实是会将prebuild的那些,还有required那些库拷到本地来编译 |
LOCAL_AAPT_FLAGS := --auto-add-overlay \ --extra-packages com.coagent.pub
aapt即Android Asset Packaging Tool,在SDK的build-tools目录下。该工具可以查看,创建, 更新ZIP格式的文档附件(zip, jar, apk)。也可将资源文件编译成二进制文件,尽管你可能没有直接使用过aapt工具,但是build scripts和IDE插件会使用这个工具打包apk文件构成一个Android 应用程序。也就是上面说的配置。
第三方jar补充:
蓝色和未框选域分别作用
框选:mk文件编译具体执行逻辑
未框选:用于LOCAL_STATIC_JAVA_LIBRARIES加载jar初始化作用文件域,名字虚对应(系统预制的,例如:android-support-v4就不需要我们在初始化域中配置)
mk文件跟src,res,AndroidManifest.xml文件不在同一级目录,需要配置全路径,具体原因不明,有待查明