Android.mk 语法参考文件

本文详细介绍了在Android.mk中如何编译出多个.so文件,包括使用CLEAR_VARS变量进行多库编译的方法及all-subdir-makefiles函数的应用。提供了一个简单的范例,并解释了相关变量的作用。

下载NDK,最好使用r8版本以后的,因为之后的版本不需要再去配置cygwin了。

解压,配置NDK的路径,windows中配置环境变量即可。

参考文件:~\docs\ANDROID-MK.html

详细阅读说明文档。

 

简单范例如下:

---------- cut here ------------------ 

  LOCAL_PATH := $(call my-dir) 

  include $(CLEAR_VARS)  

 LOCAL_MODULE    := hello-jni 

  LOCAL_SRC_FILES := hello-jni.c 

  include $(BUILD_SHARED_LIBRARY)  

 ---------- cut here ------------------

问题:

1. 如何考虑在Android.mk中编译出多个so文件?

include $(CLEAR_VARS)

The CLEAR_VARS variable is provided by the build system and points to aspecial GNU Makefile that will clear many LOCAL_XXX variables for you(e.g. LOCAL_MODULE, LOCAL_SRC_FILES, LOCAL_STATIC_LIBRARIES, etc...),with the exception of LOCAL_PATH. This is needed because all buildcontrol files are parsed in a single GNU Make execution context whereall variables are global.

想编译出多个库,在一个执行结束后,调用include $(CLEAR_VARS),再写新的需要编译的源文件以及定义目标文件,应该就可以实现了。

 

也可以通过以下方式实现

all-subdir-makefiles   

 Returns a list of Android.mk located in all sub-directories of    the current 'my-dir' path. For example, consider the following    hierarchy:       

sources/foo/Android.mk       

sources/foo/lib1/Android.mk      

sources/foo/lib2/Android.mk   

If sources/foo/Android.mk contains the single line:        include $(call all-subdir-makefiles)    Then it will include automatically sources/foo/lib1/Android.mk and    sources/foo/lib2/Android.mk    This function can be used to provide deep-nested source directory    hierarchies to the build system. Note that by default, the NDK    will only look for files in sources/*/Android.mk

<think>首先,用户的问题是“Android.mk文件介绍”,我需要用中文回答。然后,根据规则,回答完问题后,必须提出3-5个相关问题,并以“§§相关问题§§”开头,禁止换行分散。 回顾规则: - 回答必须使用中文。 - 回答后必须有“§§相关问题§§”部分。 - “§§相关问题§§”必须完整输出在第一行。 - 相关问题数量:3-5个。 - 格式参考示例:回答内容,然后“§§相关问题§§”,接着是1. 2. 3. 等列表。 我的回答结构: 1. 介绍Android.mk文件。 2. 在末尾添加“§§相关问题§§”和相关问题列表。 内容要点: - Android.mkAndroid构建系统的一部分,用于定义模块的构建规则。 - 它基于GNU Make语法。 - 用于AOSP(Android Open Source Project)中编译本地代码、库、可执行文件等。 - 包含变量定义、目标声明等。 - 现在逐渐被Android.bp取代,但仍在一些项目中使用。 回答大纲: - 定义:Android.mk是Makefile格式的文件,用于描述如何构建Android模块。 - 作用:指定源代码、依赖、编译选项等。 - 关键元素:LOCAL_PATH, include $(CLEAR_VARS), LOCAL_MODULE, LOCAL_SRC_FILES, include $(BUILD_SHARED_LIBRARY) 等。 - 示例:给出一个简单的代码片段。 - 注意:强调它在现代AOSP中的角色和迁移趋势。 添加代码示例:类似于示例格式,我需要提供一个代码块。用户的问题是关于Android.mk的介绍,所以我可以展示一个简单的Android.mk文件。 例如: ```makefile LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) LOCAL_MODULE := my_module LOCAL_SRC_FILES := my_source.c include $(BUILD_SHARED_LIBRARY) ``` 然后,解释这个代码。 之后,提出相关问题。 相关问题必须基于用户的问题和我的回答。用户的问题是“Android.mk文件介绍”,我的回答是关于Android.mk的。 可能的3-5个相关问题: 1. Android.mkAndroid.bp的主要区别是什么? 2. 如何迁移Android.mkAndroid.bp? 3. Android.mk中的常见变量有哪些及其作用? 4. 如何在AOSP中添加一个新的Android.mk模块? 5. Android.mk构建过程中的常见错误及解决方法? 确保数量在3-5个。 最后,输出格式: - 回答内容(包括代码块)。 - 然后“§§相关问题§§”在单独一行。 - 接着是编号列表:1. 2. 3. 等。 完整输出: [回答内容] §§相关问题§§ 1. ... 2. ... 3. ...</think>Android.mkAndroid构建系统(AOSP)中用于定义模块编译规则的核心文件,基于GNU Make语法。它通过声明变量和包含预定义模板来指定源代码、依赖项、编译标志及输出类型(如共享库、可执行文件或APP)。关键元素包括: - `LOCAL_PATH := $(call my-dir)`:设置当前模块路径。 - `include $(CLEAR_VARS)`:清除变量以开始新模块定义。 - `LOCAL_MODULE`:定义模块名称(如`libdemo`)。 - `LOCAL_SRC_FILES`:列出源文件(如`main.cpp`)。 - `include $(BUILD_*)`:指定构建类型(如`BUILD_SHARED_LIBRARY`生成共享库)。 示例代码: ```makefile LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) LOCAL_MODULE := native_demo LOCAL_SRC_FILES := native_code.cpp LOCAL_SHARED_LIBRARIES := liblog include $(BUILD_SHARED_LIBRARY) ``` 此文件用于传统AOSP项目,但正逐步被Android.bp取代,因其声明式语法更简洁且支持Soong构建系统。开发者需注意兼容性,如通过`Android.mk`调用`ndk-build`编译本地代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值