当前位置: 代码迷 >> Ruby/Rails >> Android NDK 运行异常:java.lang.UnsatisfiedLinkError: Couldn't load XXX indLibrary returned null
  详细解决方案

Android NDK 运行异常:java.lang.UnsatisfiedLinkError: Couldn't load XXX indLibrary returned null

热度:241   发布时间:2016-04-29 02:12:26.0
Android NDK 运行错误:java.lang.UnsatisfiedLinkError: Couldn't load XXX indLibrary returned null

今天将一个带有C++的android混合项目倒出的Android Studio,运行起来出现了如下错误:

5-31 18:45:52.320  10741-10741/com.example.hellojni E/AndroidRuntime﹕ FATAL EXCEPTION: main    Process: com.example.hellojni, PID: 10741    java.lang.UnsatisfiedLinkError: Couldn't load hello-jni from loader dalvik.system.PathClassLoader[DexPathList[[zip file "/data/app/com.example.hellojni-1.apk"],nativeLibraryDirectories=[/data/app-lib/com.example.hellojni-1, /vendor/lib, /system/lib]]]: findLibrary returned null            at java.lang.Runtime.loadLibrary(Runtime.java:358)            at java.lang.System.loadLibrary(System.java:526)            at com.example.hellojni.HelloJni.<clinit>(HelloJni.java:64)            at java.lang.Class.newInstanceImpl(Native Method)            at java.lang.Class.newInstance(Class.java:1208)            at android.app.Instrumentation.newActivity(Instrumentation.java:1061)            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2107)            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2239)            at android.app.ActivityThread.access$800(ActivityThread.java:141)            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1202)            at android.os.Handler.dispatchMessage(Handler.java:102)            at android.os.Looper.loop(Looper.java:136)            at android.app.ActivityThread.main(ActivityThread.java:5047)            at java.lang.reflect.Method.invokeNative(Native Method)            at java.lang.reflect.Method.invoke(Method.java:515)            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:609)            at dalvik.system.NativeStart.main(Native Method)

我的.so文件什么都有,而且所有的CPU架构都支持了,为什么找不到呢?有可能你的是没有添加所有的平台哦!!!

方法1

原来是Android Studio的JNI默认路径是这样的

//目录结构一定要改成这个样子|---src     |---main           |---jniLibs                  |---arm64-v8a                         |---libhello-jni.so                  |---armeabi                         |---libhello-jni.so                  |---armeabi-v7a                         |---libhello-jni.so                  |---x86                         |---libhello-jni.so                  |---x86_64                         |---libhello-jni.so                  |---mips                         |---libhello-jni.so                  |---mips64                         |---libhello-jni.so

目录结构一定要改成上图的样子,详细的修改方法请转移 | Android Studio 添加动态库os文件的方法

方法2[推荐]

直接修改build.gradle文件如下:

android {    sourceSets {        main {            jniLibs.srcDirs = ['libs']        }}

其实两种方法的原理是一样的。

方法1是:直接将so文件放到了Android Studio 的默认路径src > main > jniLibs

方法2是:修改jniLibs的默认路径为libs

  相关解决方案