详解Android.mk文件:NDK编译指南

文章摘要

本文解析了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_MODULELOCAL_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

参考


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

你一身傲骨怎能输

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值