android.mk

一个Android.mk文件可以编译多个模块, 每个模块属下列类型之一
  1)APK程序:一般的Android程序,编译打包生成apk文件
  2)JAVA库:java类库,编译打包生成jar文件
  3)  C\C++应用程序:可执行的C\C++应用程序
  4)C\C++静态库:编译生成C\C++静态库,并打包成.a文件
  5)C\C++共享库:编译生成共享库(动态链接库),并打包成.so文, 有且只有共享库才能被安装/复制到您的应用软件(APK)包中。


看一个简单的"hello world"的例子,比如,下面的文件:

 sources/helloworld/helloworld.c
 sources/helloworld/Android.mk
 'helloworld.c'是一个 JNI  共享库 ,实现返回"hello world"字符串的原生方法。相应的Android.mk 文件会象下面这样:
LOCAL_PATH := $(call my-dir)  # 宏函数‘my-dir’,  由编译系统提供, 用于返回当前路径
include $(CLEAR_VARS)   #CLEAR_VARS 由编译系统提供该语句的意思就是把CLEAR_VARS变量所指向的脚本文件($(BUILD_SYSTEM)/clear_vars.mk)包含进来。
LOCAL_MODULE:= helloworld  #LOCAL_MODULE 变量必须定义,标识你在 Android.mk 文件中描述的每个模块
LOCAL_SRC_FILES := helloworld.c  #包含将要编译打包进模块中的 C 或 C++源代码文件
include $(BUILD_SHARED_LIBRARY)  #BUILD_SHARED_LIBRARY 是编译系统提供的变量,指向一个 GNU Makefile 脚本

GNU Make‘功能’宏

all-subdir-makefiles: 返回一个位于当前'my-dir'路径的子目录中的所有Android.mk的列表

this-makefile:  返回当前Makefile 的路径

parent-makefile:  返回调用树中父 Makefile 路径。


Android.mk 使用模板

1)编译APK应用程序模板。
关于编译APK应用程序的模板请参照 Android.mk编译APK范例
(2)编译JAVA库模板
  LOCAL_PATH := $(call my-dir)
  include $(CLEAR_VARS)
  # Build all java files in the java subdirectory
  LOCAL_SRC_FILES := $(call all-subdir-java-files)
  # Any libraries that this library depends on
   LOCAL_JAVA_LIBRARIES := android.test.runner
  # The name of the jar file to create
  LOCAL_MODULE := sample
  # Build a static jar file.
  include $( BUILD_STATIC_JAVA_LIBRARY )
  :LOCAL_JAVA_LIBRARIES := android.test.runner表示生成的JAVA库的jar文件名
(3)编译C/C++应用程序模板如下
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  表示以一个可执行程序的方式进行编译。
(4)编译C\C++静态库
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 表示编译一个静态库。
(5)编译C\C++动态库的模板
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/APPS
out/target/product/generic/obj/JAVA_LIBRARIES
out/target/product/generic/obj/EXECUTABLE
out/target/product/generic/obj/STATIC_LIBRARY
out/target/product/generic/obj/SHARED_LIBRARY
每个模块的目标文件夹分别为
 1) APK程序 :XXX_intermediates
 2) JAVA库程序 :XXX_intermediates
 3) C\C++可执行程序 :XXX_intermediates
 4) C\C++静态库 : XXX_static_intermediates
 5) C\C++动态库 : XXX_shared_intermediates




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值