文章摘要
本文解析了Android NDK中Android.mk文件的关键指令。首先,LOCAL_PATH定义当前目录,include $(CLEAR_VARS)清除变量;接着通过LOCAL_MODULE指定模块名(如hello会生成libhello.so),LOCAL_SRC_FILES定义源文件;最后BUILD_SHARED_LIBRARY决定生成动态库。类比传统Makefile,这些指令分别对应目录设置、目标命名、源文件指定和构建类型。还介绍了多文件编译和头文件包含的扩展用法。
1. LOCAL_PATH := $(call my-dir)
- 作用:设置当前模块的路径为当前
Android.mk
文件所在目录。 - 解释:
my-dir
是 NDK 提供的一个函数,返回当前Android.mk
文件的目录路径。这样后续的文件路径都可以用相对路径来写。
2. include $(CLEAR_VARS)
- 作用:清除之前定义的所有本地变量(如
LOCAL_MODULE
、LOCAL_SRC_FILES
等)。 - 解释:每定义一个新的模块(库),都要先
include $(CLEAR_VARS)
,防止变量污染。
3. LOCAL_MODULE := hello
- 作用:指定要生成的模块(库)的名字。
- 解释:最终会生成
libhello.so
,NDK 会自动加上lib
前缀和.so
后缀。
4. LOCAL_SRC_FILES := hello.c
- 作用:指定本模块要编译的源文件。
- 解释:这里只编译
hello.c
,如果有多个源文件可以用空格分隔:a.c b.c c.c
。
5. include $(BUILD_SHARED_LIBRARY)
- 作用:指定要构建的是一个动态库(.so 文件)。
- 解释:如果要编译静态库,应该用
include $(BUILD_STATIC_LIBRARY)
。
总结
这个 Android.mk
文件的意思是:
- 在当前目录下,编译
hello.c
,生成一个名为libhello.so
的动态库。
类比传统 Makefile
Android.mk 变量 | 传统 Makefile 作用 |
---|---|
LOCAL_PATH | 当前目录 |
LOCAL_MODULE | 目标名(不带lib和.so) |
LOCAL_SRC_FILES | 源文件列表 |
BUILD_SHARED_LIBRARY | 生成动态库 |
扩展:多个源文件和头文件
LOCAL_SRC_FILES := hello.c foo.c bar.c
LOCAL_C_INCLUDES := $(LOCAL_PATH)/include