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语法解析

    什么是Android.mk Android.mk是Android提供的一种makefile文件,用来指定诸如编译生...

  • 2019-05-30

    转自 Android.mk 文件语法详解 ====================================...

  • cocos2d-x 系列

    NDK mk文件语法 0. Android.mk简介: Android.mk文件用来告知NDK Build 系统关...

  • Android.mk语法

    翻译自docs/ANDROID-MK.html Indroduction 本篇文档描述Andrid.mk编译文件的...

  • Android.mk解析

    一 简介 Android NDK的构建系统是基于GUN Makefile的,Android.mk其实就是一个用于向...

  • Android.mk解析

    Android.mk解析 一、变量说明: 1.LOCAL_PATH:= $(call my-dir) 此行代码在A...

  • 2018-08-09

    mark 引用如下的链接文章 Android.mk 文件语法详解 转:http://blog.sina.com.c...

  • React基础(一)

    react 语法 1.引入依赖文件 jsx语法:遇到<>按照html语法解析;遇到{}按照js语法解析 2.Rea...

  • Android.mk语法说明

    版权申明: 本文原创首发于以下网站,您可以自由转载,但必须加入完整的版权声明 博客园:https://www.cn...

  • Android.mk语法详解

    LOCAL_PATH := $(call my-dir)每个Android.mk文件必须以定义LOCAL_PATH...

网友评论

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

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