jni使用基础(三)之Android.mk文件详解-阿里云开发者社区

开发者社区> 开发与运维> 正文
登录阅读全文

jni使用基础(三)之Android.mk文件详解

简介:

 

 

Android.mk文件详细说明:

LOCAL_PATH:=$(call my-dir)//调用编译链的函数

LOCAL_PATH是定义源文件在哪个目录用的.

my-dir 是个定义的宏方法,

 $(call my-dir)就是调用这个叫 my-dir的宏方法,这个方法返回值就是Android.mk文件所在的目录

 

include $(CLEAR_VARS)//类似工具的初始化操作

CLEAR_BARS 变量是build system里面的一个变量
这个变量指向了所有的类似 LOCAL_XXX的变量,
执行完这一句话, 这个编译系统就把 所有的类似
LOCAL_MODULE,LOCAL_SRC_FILES,LOCAL_STATIC_LIBRARIES,...这样的变量都清除掉
但是不会清除掉 LOCAL_PATH

 

LOCAL_MODULE  就是你要生成的库的名字,这个名字要是唯一的.不能有空格.
编译后系统会自动在前面加上lib的头, 比如说我们的Hello 就编译成了libHello.so

还有个特点就是如果你起名叫libHello 编译后ndk就不会给你的module名字前加上lib了

但是你最后调用的时候 还是调用Hello这个库

 

LOCAL_SRC_FILES = :Hello.c  //(当有多个c文件,以“,”分隔开)
这个是指定你要编译哪些文件
不需要指定头文件 ,引用哪些依赖, 因为编译器会自动找到这些依赖 自动编译


include $(BUILD_SHARED_LIBRARY) //告诉编译器编译出来的库文件是一个动态库

                BUILD_STATIC_LIBRARY   //静态库编译参数

.so编译后生成的库的类型,

如果是静态库.a 配置include $(BUILD_STATIC_LIBRARY)


别的参数

LOCAL_CPP_EXTENSION := cc //指定c++文件的扩展名
LOCAL_MODULE    := ndkfoo
LOCAL_SRC_FILES := ndkfoo.cc

LOCAL_LDLIBS += -llog -lvmsagent -lmpnet -lmpxml -lH264Android
//指定需要加载一些别的什么库.

动态库和静态库的区别:

  动态库的体积会比较小,是以.so为扩展名

   静态库的体积比较大,是以.a为扩展名

大小原因:动态库里面只包含的它运行所依赖的一些环境的配置信息,也就是它在运行的时候,

                   它会动态的从操作系统中,根据配置信息获取它运行所需的内容

                   静态库被编译后,它所有依赖的文件,都加入到编译后的.a文件中了。

 

所以,在使用动态库的时候,如果手机中没有支持动态库所需的内容时,就无法使用

           so文件,而静态库是不需要关心平台问题,它不需要去系统中找相应的引用文件。

 

 

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
开发与运维
使用钉钉扫一扫加入圈子
+ 订阅

集结各类场景实战经验,助你开发运维畅行无忧

其他文章
最新文章
相关文章