android ndk 调用第三方so

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) 

你可能感兴趣的:(android,object,Module,Build,Path,library)