Android.mk语法解析

作者: Lee_5566 | 来源:发表于2019-01-20 11:52 被阅读1次

    什么是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++语言那样实现应用程序的一部分。


    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

    相关文章

      网友评论

        本文标题:Android.mk语法解析

        本文链接:https://www.haomeiwen.com/subject/qgwgdqtx.html