Android.mk介绍

摘自:http://blog.chinaunix.net/u3/99423/showart_2206760.html

在一个Android.mk中可以生成多个可执行程序、动态库和静态库。

1,编译应用程序的模板:

     #Test Exe

     LOCAL_PATH := $(call my-dir)

     #include $(CLEAR_VARS)

     LOCAL_SRC_FILES:= main.c

     LOCAL_MODULE:= test_exe

     #LOCAL_C_INCLUDES :=

     #LOCAL_STATIC_LIBRARIES :=

     #LOCAL_SHARED_LIBRARIES :=

     include $(BUILD_EXECUTABLE)

(菜鸟级别解释::=是赋值的意思,$是引用某变量的值)LOCAL_SRC_FILES中加入源文件路径,LOCAL_C_INCLUDES 中加入所需要包含的头文件路径,LOCAL_STATIC_LIBRARIES加入所需要链接的静态库(*.a)的名称,LOCAL_SHARED_LIBRARIES中加入所需要链接的动态库(*.so)的名称,LOCAL_MODULE表示模块最终的名称,BUILD_EXECUTABLE表示以一个可执行程序的方式进行编译。

2,编译静态库的模板:

     #Test Static Lib

     LOCAL_PATH := $(call my-dir)

     include $(CLEAR_VARS)

     LOCAL_SRC_FILES:= /

               helloworld.c

     LOCAL_MODULE:= libtest_static

     #LOCAL_C_INCLUDES :=

     #LOCAL_STATIC_LIBRARIES :=

     #LOCAL_SHARED_LIBRARIES :=

     include $(BUILD_STATIC_LIBRARY)

一般的和上面相似,BUILD_STATIC_LIBRARY表示编译一个静态库。

3,编译动态库的模板:

     #Test Shared Lib

     LOCAL_PATH := $(call my-dir)

     include $(CLEAR_VARS)

     LOCAL_SRC_FILES:= /

               helloworld.c

     LOCAL_MODULE:= libtest_shared

     TARGET_PRELINK_MODULES := false

     #LOCAL_C_INCLUDES :=

     #LOCAL_STATIC_LIBRARIES :=

     #LOCAL_SHARED_LIBRARIES :=

      include $(BUILD_SHARED_LIBRARY)

一般的和上面相似,BUILD_SHARED_LIBRARY表示编译一个共享库。

 

以上三者的生成结果分别在如下,generic依具体target会变:

out/target/product/generic/obj/EXECUTABLE

out/target/product/generic/obj/STATIC_LIBRARY

out/target/product/generic/obj/SHARED_LIBRARY

      每个模块的目标文件夹分别为:

可执行程序:XXX_intermediates

静态库:      XXX_static_intermediates

动态库:      XXX_shared_intermediates

      另外,在Android.mk文件中,还可以指定最后的目标安装路径,用LOCAL_MODULE_PATH和LOCAL_UNSTRIPPED_PATH来指定。不同的文件系统路径用以下的宏进行选择:

TARGET_ROOT_OUT:表示根文件系统。

TARGET_OUT:表示system文件系统。

TARGET_OUT_DATA:表示data文件系统。

用法如:

LOCAL_MODULE_PATH:=$(TARGET_ROOT_OUT)

<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、付费专栏及课程。

余额充值