Android導(dǎo)入第三方靜態(tài)庫(kù).a編譯成動(dòng)態(tài)庫(kù).so
在Android開(kāi)發(fā)的時(shí)候,經(jīng)常會(huì)使用到用c或c++編寫(xiě)的第三方的靜態(tài)庫(kù)。如果有源碼的話,可以直接跟你自己的代碼一去編譯成動(dòng)態(tài)庫(kù)so,但是如果沒(méi)有源碼的話,你就必須在自己的動(dòng)態(tài)庫(kù)so里面將別人生成好的靜態(tài)庫(kù)導(dǎo)入進(jìn)來(lái)一起編譯了。我在編譯的時(shí)候遇到了不少問(wèn)題,我覺(jué)得有必要進(jìn)行總結(jié)一下。
下面我以一個(gè)簡(jiǎn)單的實(shí)際例子來(lái)講解如何在動(dòng)態(tài)庫(kù)中導(dǎo)入靜態(tài)庫(kù)。
靜態(tài)庫(kù)中的源代碼有兩個(gè)文件:static.h, static.c,有一個(gè)add方法
static.h
#include
int add(int x, int y);
static.c
#include "static.h"
int add(int x, int y)
{
return x + y;
}
將它編譯成靜態(tài)庫(kù),Android.mk如下:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE := static_add
LOCAL_SRC_FILES := static.c
include $(BUILD_STATIC_LIBRARY)
注意編譯靜態(tài)庫(kù)的時(shí)候,必須有一個(gè)Application.mk文件:
APP_MODULES:=static_add
APP_MODULES的值應(yīng)該和Android.mk中的LOCAL_MODULE的值保持一樣。
然后調(diào)用ndk-build進(jìn)行編譯生成libstatic_add.a靜態(tài)庫(kù)。
hejinlai_iMac:jni hejinlai$ ndk-build
Prebuilt : libstatic_add.a <= jni/
生成靜態(tài)庫(kù)后,然后編寫(xiě)動(dòng)態(tài)庫(kù)中的源代碼: share.h share.c
share.h
#include
int test_add(int x, int y);
share.c
1234567 #include "share.h"
#include "static.h"
int test_add(int x, int y)
{
// 調(diào)用static里面的方法
return add(x, y);
}
編寫(xiě)導(dǎo)入靜態(tài)庫(kù)的Android.mk:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE := static_add
LOCAL_SRC_FILES := libstatic_add.a
include $(PREBUILT_STATIC_LIBRARY)
include $(CLEAR_VARS)
LOCAL_MODULE := share_add
LOCAL_STATIC_LIBRARIES := static_add
LOCAL_SRC_FILES := share.c
include $(BUILD_SHARED_LIBRARY)
注意上面生成的libstatic_add.a必須跟Android.mk放在同一目錄下,否則需要填寫(xiě)相應(yīng)的路徑,然后進(jìn)行編譯:
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鏈接到相應(yīng)的路徑