http://www.eoeandroid.com/thread-55467-1-1.html
首先需要確定的是你的.so是否是android支援的,不是所有的.so都可以的,本身就分為linux-X86和linux-arm兩個大類。查看so是不是編譯成ARM模式下的so
$ file libtest.so
libtest.so: ELF 32-bit LSB shared object, ARM, version 1 (SYSV), dynamically linked, not stripped如果這樣就是支援的。PS ndk-build產生的.so肯定是支援的。
http://kaneiqi.iteye.com/blog/666816
http://blog.csdn.net/victoryckl/article/details/6832333
http://blog.csdn.net/vrix/archive/2010/03/06/5351196.aspx
已有一個so檔案,名為"libold.so"。其中有方法"int oldmethod()"。
現在由於某些原因,介面變化,或根本不知道old.so中介面,但要用到oldmethod方法,因此,用一個新的介面,若介面為"jint Java_com_example_newmethod( JNIEnv*,jobject)"
產生新的so檔案,來使用。
mynewlib.c檔案如下:
#include <string.h>
#include <jni.h>
#include <dlfcn.h>
jint
Java_com_example_tnewmethod(( JNIEnv* env, jobject thiz )
{
void* filehandle = dlopen("/data/data/com.example/lib/libold.so", RTLD_LAZY ); // 開啟原so檔案
if(filehandle)
{
int( * oldmethod) ();
oldmethod= dlsym(filehandle, "oldmethod"); //引入原so中的函數
if( oldmethod)
{
//調用該函數
}
}
}
這裡的dlopen和dlsym是android中/system/lib下libdl.so中的函數。因此需要把這個檔案從android中匯出,在模擬器中直接pull就可以了。之後在編譯so時沒有link到這個so,編譯會失敗。有了該檔案後,Android.mk如下:
LOCAL_PATH := $(call my-dir)
LOCAL_MODULE := my-new-lib
LOCAL_SRC_FILES := mynewlib.c
# 這裡link了libdl.so,好像放在ANDROID_NDK_ROOT路徑下,不對的話,看編譯出錯的資訊也能夠找到正確的路徑吧
LOCAL_LDLIBS := -L . -ldl
include $(BUILD_SHARED_LIBRARY)