Android.mk Application.mk CMakeLists.txt

1.编译静态库
文件Android.mk:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE := hello-jni
LOCAL_SRC_FILES := hello-jni.c
include $(BUILD_STATIC_LIBRARY)
文件Application.mk:
APP_MODULES :=hello-jni

2.编译动态库
文件Android.mk:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE := hello-jni
LOCAL_SRC_FILES := hello-jni.c
include $(BUILD_SHARED_LIBRARY)

3.编译动态库+静态库
文件Android.mk:
LOCAL_PATH := $(call my-dir)

include $(CLEAR_VARS)
LOCAL_MODULE := mylib_static
LOCAL_SRC_FILES := src.c
include $(BUILD_STATIC_LIBRARY)

include $(CLEAR_VARS)
LOCAL_MODULE := mylib_shared
LOCAL_SRC_FILES := src2.c

LOCAL_STATIC_LIBRARIES := mylib_static

include $(BUILD_SHARED_LIBRARY)

4.已有第三方静态库(动态库),编译静态库(动态库)
文件Android.mk:

LOCAL_PATH := $(call my-dir)

include $(CLEAR_VARS)
LOCAL_MODULE := thirdlib1 # name it whatever
LOCAL_SRC_FILES := $(TARGET_ARCH_ABI)/libthird1.a # or $(so_path)/libthird1.so
#LOCAL_EXPORT_C_INCLUDES := $(LOCAL_PATH)/include
include $(PREBUILT_STATIC_LIBRARY) #or PREBUILT_SHARED_LIBRARY

include $(CLEAR_VARS)
LOCAL_MODULE := mylib_use_thirdlib
LOCAL_SRC_FILES := src.c

LOCAL_STATIC_LIBRARIES := thirdlib1 #or LOCAL_SHARED_LIBRARY

include $(BUILD_SHARED_LIBRARY) #如果编译静态库,需要 Application.mk

原文:https://blog.csdn.net/heng615975867/article/details/11904737


  • 只有动态库可以被 install/copy到应用程序包(APK). 静态库则可以被链接入动态库。

  • LOCAL_PATH := $(call my-dir)
    每个Android.mk文件必须以定义LOCAL_PATH为开始。它用于在开发tree中查找源文件。宏my-dir 则由NDK Build System提供。返回包含Android.mk的目录路径。

  • include $(CLEAR_VARS)
    CLEAR_VARS 变量由NDK Build System提供。并指向一个指定的GNU Makefile,由它负责清理很多LOCAL_xxx.例如:LOCAL_MODULE, LOCAL_SRC_FILES, LOCAL_STATIC_LIBRARIES等等。但不清理LOCAL_PATH.这个清理动作是必须的,因为所有的编译控制文件由同一个GNU Make解析和执行,其变量是全局的。所以清理后才能避免相互影响。

  • LOCAL_MODULE := hello-jni
    LOCAL_MODULE模块必须定义,以表示Android.mk中的每一个模块。名字必须唯一且不包含空格。Build System会自动添加适当的前缀和后缀。例如,foo,要产生动态库,则生成libfoo.so. 但请注意:如果模块名被定为:libfoo.则生成libfoo.so. 不再加前缀。

  • LOCAL_SRC_FILES := hello-jni.c
    LOCAL_SRC_FILES变量必须包含将要打包如模块的C/C++ 源码。不必列出头文件,build System 会自动帮我们找出依赖文件。缺省的C++源码的扩展名为.cpp. 也可以修改,通过LOCAL_CPP_EXTENSION。

  • include $(BUILD_SHARED_LIBRARY)
    BUILD_SHARED_LIBRARY:是Build System提供的一个变量,指向一个GNU Makefile Script。它负责收集自从上次调用 include $(CLEAR_VARS) 后的所有LOCAL_XXX信息。并决定编译为什么。
    BUILD_STATIC_LIBRARY:编译为静态库。
    BUILD_SHARED_LIBRARY :编译为动态库
    BUILD_EXECUTABLE:编译为Native C可执行程序

  • NDK Build System 保留以下变量名:
    以LOCAL_ 为开头的、以PRIVATE_ ,NDK_ 或者APP_ 开头的名字、小写字母名字:如my-dir

  • BUILD_SHARED_LIBRARY:指向一个编译脚本,它收集自从上次调用 include $(CLEAR_VARS) 后的所有LOCAL_XXX信息。并决定如何将你列出的Source编译成一个动态库。 注意,在包含此文件前,至少应该包含:LOCAL_MODULE and LOCAL_SRC_FILES 例如: include $(BUILD_SHARED_LIBRARY)

  • BUILD_STATIC_LIBRARY:指向一个编译脚本,收集自从上次调用 include $(CLEAR_VARS) 后的所有LOCAL_XXX信息。并决定如何将你列出的Source编译成一个静态库。 静态库不能够加入到Project 或者APK中。但它可以用来生成动态库。LOCAL_STATIC_LIBRARIES and LOCAL_WHOLE_STATIC_LIBRARIES将描述之。 include $(BUILD_STATIC_LIBRARY)

  • PREBUILT_SHARED_LIBRARY:
    把这个共享库声明为 “一个” 独立的模块。 指向一个build 脚本,用来指定一个预先编译好多动态库。 与BUILD_SHARED_LIBRARY and BUILD_STATIC_LIBRARY不同,此时模块的LOCAL_SRC_FILES应该被指定为一个预先编译好的动态库,而非source file. LOCAL_PATH := $(call my-dir)
    include $(CLEAR_VARS)
    LOCAL_MODULE := foo-prebuilt # 模块名
    LOCAL_SRC_FILES := libfoo.so # 模块的文件路径(相对于 LOCAL_PATH)
    include $(PREBUILT_SHARED_LIBRARY) # 注意这里不是 BUILD_SHARED_LIBRARY
    这个共享库将被拷贝到 $PROJECT/obj/local 和 $PROJECT/libs/ (stripped) 主要是用在将已经编译好的第三方库

  • PREBUILT_STATIC_LIBRARY:
    预先编译的静态库

  • LOCAL_MODULE_FILENAME:
    可选。用来override LOCAL_MODULE. 即允许用户重新定义最终生成的目标文件名。 LOCAL_MODULE := foo-version-1 LOCAL_MODULE_FILENAME := libfoo

  • LOCAL_CPP_EXTENSION:
    指出C++ 扩展名。(可选)
    LOCAL_CPP_EXTENSION := .cxx 从NDK R7后,可以写多个:
    LOCAL_CPP_EXTENSION := .cxx .cpp .cc

  • LOCAL_C_INCLUDES:
    一个可选的path列表。相对于NDK ROOT 目录。编译时,将会把这些目录附上。
    LOCAL_C_INCLUDES := sources/foo LOCAL_C_INCLUDES := $(LOCAL_PATH)/…/foo

  • LOCAL_STATIC_LIBRARIES:
    要链接到本模块的静态库list。(built with BUILD_STATIC_LIBRARY)

  • LOCAL_SHARED_LIBRARIES:
    要链接到本模块的动态库。

  • LOCAL_WHOLE_STATIC_LIBRARIES:
    静态库全链接。 不同于LOCAL_STATIC_LIBRARIES,类似于使用–whole-archive

  • LOCAL_LDLIBS:
    linker flags。 可以用它来添加系统库。 如 -lz:
    LOCAL_LDLIBS := -lz

  • BUILD_PREBUILT:
    该模块已经预先编译

原文:https://www.cnblogs.com/wainiwann/p/3837936.html



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值