什么是Android.mk
Android.mk是Android提供的一种makefile文件,用来指定诸如编译生成so库名、引用的头文件目录、需要编译的.c/.cpp文件和.a静态库文件等。
Android.mk文件用来告知NDK Build系统关于Source的信息。 Android.mk将是GNU Makefile的一部分,且将被Build System解析一次或多次。
所以,请尽量少的在Android.mk中声明变量,也不要假定任何东西不会在解析过程中定义。
什么是NDK
Android NDK(Native Development Kit )是一套工具集合,允许你用像C/C++语言那样实现应用程序的一部分。
Android.mk文件语法允许我们将Source打包成一个"modules". modules可以是:
1. 静态库
2. 动态库
基本语法:
Simple example
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE := hello-jni
LOCAL_SRC_FILES := hello-jni.c
include $(BUILD_SHARED_LIBRARY)
语法介绍
现在,让我们解释一下这些行。
LOCAL_PATH
LOCAL_PATH := $(call my-dir)
android.mk文件必须以本地路径变量的定义开始。
它用于在开发树中定位源文件。在本例中,由构建系统提供的宏函数'my dir'用于返回当前目录的路径(即包含android.mk文件本身的目录)。
CLEAR_VARS
include $(CLEAR_VARS)
clear_vars变量由构建系统提供,并指向一个特殊的GNU makefile,它将为您清除许多LOCAL_xxx变量。例如LOCAL_MODULE、OCAL_SRC_FILES、LOCAL_STATIC_LIBRARIES等),LOCAL_PATH除外。
这是必需的,因为所有的构建控制文件在一个gnu make执行上下文中解析,其中所有变量都是全局的。
LOCAL_MODULE
LOCAL_MODULE := hello-jni
必须定义LOCAL_MODULE变量以标识您在android.mk中描述的每个模块。
名称必须是唯一且不包含任何空间。
请注意,构建系统将自动向相应生成的文件添加适当的前缀和后缀。换言之,名为“foo”的共享库模块将生成“libfoo.so”。
如果您将模块命名为“libfoo”,则生成系统不会添加另一个“lib”前缀,也会生成libfoo.so。
LOCAL_SRC_FILES
LOCAL_SRC_FILES := hello-jni.c
LOCAL_SRC_FILES变量必须包含C和/或C++源文件的列表,这些文件将被构建并组装到模块中。
注意你应该这里不列出头文件和包含的文件,因为构建系统将自动为您计算依赖项;只列出源文件这将直接传递给编译器。
注意,C++源文件的默认扩展名是“.CPP”。但是,可以通过定义变量LOCAL_CPP_EXTENSION来指定不同的变量本地扩展名。不要忘记初始点(即“.cxx”有效,而不是“cxx”)。
LOCAL_SRC_FILES
include $(BUILD_SHARED_LIBRARY)
BUILD_SHARED_LIBRARY是由构建系统提供的一个变量,它指向负责收集所有自最新“include$(clear_vars)”以来,您在本地变量中定义的信息,并确定要构建什么以及如何构建。
当然还有BUILD_STATIC_LIBRARY来生成静态库。
具体的编译变量列举:
type | describe |
---|---|
BUILD_STATIC_LIBRARY | 编译为静态库。 |
BUILD_SHARED_LIBRARY | 编译为动态库 |
BUILD_EXECUTABLE | 编译为Native C可执行程序 |
NDK语法变量汇总
NDK Build System 保留以下变量名:
- 以LOCAL_ 为开头的
- 以PRIVATE_ ,NDK_ 或者APP_ 开头的名字。
- 小写字母名字:如my-dir
如果想要定义自己在Android.mk中使用的变量名,建议添加MY_前缀。
type | example | describ |
---|---|---|
CLEAR_VARS | include $(CLEAR_VARS) | 必须在新模块前包含之 |
BUILD_SHARED_LIBRARY | include $(BUILD_SHARED_LIBRARY) | 决定如何将你列出的Source编译成一个动态库 |
BUILD_STATIC_LIBRARY | include $(BUILD_STATIC_LIBRARY) | 决定如何将你列出的Source编译成一个静态库 |
BUILD_EXECUTABLE | 决定如何将你列出的Source编译成一个可执行Native程序 | include $(BUILD_EXECUTABLE) |
PREBUILT_SHARED_LIBRARY | include $(PREBUILT_SHARED_LIBRARY) | 把这个共享库声明为 “一个” 独立的模块 |
PREBUILT_STATIC_LIBRARY | include $(PREBUILT_STATIC_LIBRARY) | 把这个静态库库声明为 “一个” 独立的模块 |
TARGET_ARCH | 目标CPU架构名 | |
TARGET_PLATFORM | 目标平台的名字 | |
TARGET_ARCH_ABI | ||
LOCAL_C_INCLUDES | LOCAL_C_INCLUDES := sources/foo | 一个可选的path列表。 |
LOCAL_CFLAGS | LOCAL_CFLAGS += -I<path> | 一个可选的设置,在编译C/C++ source 时添加如Flags |
LOCAL_STATIC_LIBRARIES | 要链接到本模块的静态库list | |
LOCAL_SHARED_LIBRARIES | 要链接到本模块的动态库 | |
LOCAL_LDLIBS | LOCAL_LDLIBS := -lz | 可以用它来添加系统库 |
参考:
android编译系统makefile(Android.mk)写法
Android.mk 文件语法详解
Android.mk