Android导入第三方静态库.a编译成动态库.so
在Android开发的时候,经常会使用到用c或c++编写的第三方的静态库。如果有源码的话,可以直接跟你自己的代码一去编译成动态库so,但是如果没有源码的话,你就必须在自己的动态库so里面将别人生成好的静态库导入进来一起编译了。我在编译的时候遇到了不少问题,我觉得有必要进行总结一下。
下面我以一个简单的实际例子来讲解如何在动态库中导入静态库。
静态库中的源代码有两个文件:static.h, static.c,有一个add方法
static.h
#includeint add(int x, int y);
static.c
#include "static.h"int add(int x, int y){ return x + y;}
将它编译成静态库,Android.mk如下:
LOCAL_PATH := $(call my-dir)include $(CLEAR_VARS)LOCAL_MODULE := static_addLOCAL_SRC_FILES := static.cinclude $(BUILD_STATIC_LIBRARY)
注意编译静态库的时候,必须有一个Application.mk文件:
APP_MODULES:=static_add
APP_MODULES的值应该和Android.mk中的LOCAL_MODULE的值保持一样。
然后调用ndk-build进行编译生成libstatic_add.a静态库。
hejinlai_iMac:jni hejinlai$ ndk-build
Prebuilt : libstatic_add.a <= jni/
生成静态库后,然后编写动态库中的源代码: share.h share.c
share.h
#includeint test_add(int x, int y);
share.c
#include "share.h"#include "static.h"int test_add(int x, int y){ // 调用static里面的方法 return add(x, y);}
编写导入静态库的Android.mk:
LOCAL_PATH := $(call my-dir)include $(CLEAR_VARS)LOCAL_MODULE := static_addLOCAL_SRC_FILES := libstatic_add.ainclude $(PREBUILT_STATIC_LIBRARY)include $(CLEAR_VARS)LOCAL_MODULE := share_addLOCAL_STATIC_LIBRARIES := static_addLOCAL_SRC_FILES := share.cinclude $(BUILD_SHARED_LIBRARY)
注意上面生成的libstatic_add.a必须跟Android.mk放在同一目录下,否则需要填写相应的路径,然后进行编译:
hejinlai_iMac:jni hejinlai$ ndk-build
Compile thumb : share_add <= share.c
Prebuilt : libstatic_add.a <= jni/
SharedLibrary : libshare_add.so
Install : libshare_add.so => libs/armeabi/libshare_add.so
提示so编译成功。
需要注意的是我这边share.c和static.c放在同一目录下,如果放在不同的目录下,需要指定
LOCAL_C_INCLUDES链接到相应的路径。
更多相关文章
- Android简单的使用listview动态生成不同页面
- 关于“Android SDK manager中不出现完整Android版本安装包列表”
- Android社交类APP动态详情代码实现通用模板
- Android Training - 使用碎片创建一个动态UI
- Android 6.0动态权限,单个申请与多个同时申请
- Android旅游APP类项目源代码
- Android实现多渠道打包,动态替换包名、Icon、图片等资源,解决因app
- 使用NDK编译Android所需的FFMPEG动态库
- 【Android】static静态变量的生命周期——静态之坑