Android.mk语法解析

什么是Android.mk

Android.mk是Android提供的一种makefile文件,用来指定诸如编译生成so库名、引用的头文件目录、需要编译的.c/.cpp文件和.a静态库文件等。

Android.mk文件用来告知NDK Build系统关于Source的信息。 Android.mk将是GNU Makefile的一部分,且将被Build System解析一次或多次。

所以,请尽量少的在Android.mk中声明变量,也不要假定任何东西不会在解析过程中定义。

什么是NDK

Android NDK(Native Development Kit )是一套工具集合,允许你用像C/C++语言那样实现应用程序的一部分。


11345863-60628da2008290e3.png
image.png

Android.mk文件语法允许我们将Source打包成一个"modules". modules可以是:
1. 静态库
2. 动态库

基本语法:
Simple example

   LOCAL_PATH := $(call my-dir)

   include $(CLEAR_VARS)

   LOCAL_MODULE    := hello-jni
   LOCAL_SRC_FILES := hello-jni.c

   include $(BUILD_SHARED_LIBRARY)

语法介绍

现在,让我们解释一下这些行。

LOCAL_PATH

   LOCAL_PATH := $(call my-dir)

android.mk文件必须以本地路径变量的定义开始。
它用于在开发树中定位源文件。在本例中,由构建系统提供的宏函数'my dir'用于返回当前目录的路径(即包含android.mk文件本身的目录)。

CLEAR_VARS

 include $(CLEAR_VARS)

clear_vars变量由构建系统提供,并指向一个特殊的GNU makefile,它将为您清除许多LOCAL_xxx变量。例如LOCAL_MODULE、OCAL_SRC_FILES、LOCAL_STATIC_LIBRARIES等),LOCAL_PATH除外。

这是必需的,因为所有的构建控制文件在一个gnu make执行上下文中解析,其中所有变量都是全局的。

LOCAL_MODULE

 LOCAL_MODULE := hello-jni

必须定义LOCAL_MODULE变量以标识您在android.mk中描述的每个模块。

名称必须是唯一且不包含任何空间。

请注意,构建系统将自动向相应生成的文件添加适当的前缀和后缀。换言之,名为“foo”的共享库模块将生成“libfoo.so”。

如果您将模块命名为“libfoo”,则生成系统不会添加另一个“lib”前缀,也会生成libfoo.so。

LOCAL_SRC_FILES

  LOCAL_SRC_FILES := hello-jni.c

LOCAL_SRC_FILES变量必须包含C和/或C++源文件的列表,这些文件将被构建并组装到模块中。

注意你应该这里不列出头文件和包含的文件,因为构建系统将自动为您计算依赖项;只列出源文件这将直接传递给编译器。

注意,C++源文件的默认扩展名是“.CPP”。但是,可以通过定义变量LOCAL_CPP_EXTENSION来指定不同的变量本地扩展名。不要忘记初始点(即“.cxx”有效,而不是“cxx”)。

LOCAL_SRC_FILES

 include $(BUILD_SHARED_LIBRARY)

BUILD_SHARED_LIBRARY是由构建系统提供的一个变量,它指向负责收集所有自最新“include$(clear_vars)”以来,您在本地变量中定义的信息,并确定要构建什么以及如何构建。

当然还有BUILD_STATIC_LIBRARY来生成静态库。

具体的编译变量列举:

type describe
BUILD_STATIC_LIBRARY 编译为静态库。
BUILD_SHARED_LIBRARY 编译为动态库
BUILD_EXECUTABLE 编译为Native C可执行程序

NDK语法变量汇总

NDK Build System 保留以下变量名:

  1. 以LOCAL_ 为开头的
  2. 以PRIVATE_ ,NDK_ 或者APP_ 开头的名字。
  3. 小写字母名字:如my-dir

如果想要定义自己在Android.mk中使用的变量名,建议添加MY_前缀。

type example describ
CLEAR_VARS include $(CLEAR_VARS) 必须在新模块前包含之
BUILD_SHARED_LIBRARY include $(BUILD_SHARED_LIBRARY) 决定如何将你列出的Source编译成一个动态库
BUILD_STATIC_LIBRARY include $(BUILD_STATIC_LIBRARY) 决定如何将你列出的Source编译成一个静态库
BUILD_EXECUTABLE 决定如何将你列出的Source编译成一个可执行Native程序 include $(BUILD_EXECUTABLE)
PREBUILT_SHARED_LIBRARY include $(PREBUILT_SHARED_LIBRARY) 把这个共享库声明为 “一个” 独立的模块
PREBUILT_STATIC_LIBRARY include $(PREBUILT_STATIC_LIBRARY) 把这个静态库库声明为 “一个” 独立的模块
TARGET_ARCH 目标CPU架构名
TARGET_PLATFORM 目标平台的名字
TARGET_ARCH_ABI
LOCAL_C_INCLUDES LOCAL_C_INCLUDES := sources/foo 一个可选的path列表。
LOCAL_CFLAGS LOCAL_CFLAGS += -I<path> 一个可选的设置,在编译C/C++ source 时添加如Flags
LOCAL_STATIC_LIBRARIES 要链接到本模块的静态库list
LOCAL_SHARED_LIBRARIES 要链接到本模块的动态库
LOCAL_LDLIBS LOCAL_LDLIBS := -lz 可以用它来添加系统库

参考:
android编译系统makefile(Android.mk)写法
Android.mk 文件语法详解
Android.mk

猜你喜欢

转载自blog.csdn.net/weixin_33939380/article/details/87449860