java.lang.UnsatisfiedLinkError:dlopen失败:

时间:2018-02-08 06:00:10

标签: android android-studio android-ndk

当我在我的项目中添加.so文件时,我正面临着这个问题,从其他问题来看,我尝试过不同的解决方案,但没有任何解决方案可以帮助我。

案例:1 我曾尝试将我的.so放在src / main / jniLibs和gradle文件中,我添加了以下行,但得到了同样的错误。

 android {
     sourceSets.main.jni.srcDirs = []
}

案例:2 我添加了带有native-lib.cpp的cpp文件夹,并在gradle中添加了以下代码:

defaultConfig {
 ndk {
        abiFilters "armeabi", "armeabi-v7a", "x86", "mips"
  }
   }

案例:3 我创建了支持c / c ++的新项目,并在cpp文件夹下添加了一个.so文件,并在gradle中添加了以下代码:

defaultConfig {
  externalNativeBuild {
        cmake {
            cppFlags "-std=c++11"

        }
    }
}

My project architecture

错误代码:

FATAL EXCEPTION: main
Process: ai.kitt.snowboy.demo, PID: 15175
java.lang.UnsatisfiedLinkError: dalvik.system.PathClassLoader[DexPathList[[zip file "/data/app/ai.kitt.snowboy.demo-1/base.apk"],nativeLibraryDirectories=[/vendor/lib, /system/lib]]] couldn't find "libsnowboy-detect-android.so" 
 at java.lang.Runtime.loadLibrary(Runtime.java:366)
 at java.lang.System.loadLibrary(System.java:988)
 at ai.kitt.snowboy.audio.RecordingThread.<clinit>(RecordingThread.java:20)
 at ai.kitt.snowboy.Demo.onCreate(Demo.java:49)
 at android.app.Activity.performCreate(Activity.java:6010)
 at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1129)
 at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2292)
 at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2413)
 at android.app.ActivityThread.access$800(ActivityThread.java:155)  
 at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1317)
 at android.os.Handler.dispatchMessage(Handler.java:102)
 at android.os.Looper.loop(Looper.java:135)
 at android.app.ActivityThread.main(ActivityThread.java:5343)
 at java.lang.reflect.Method.invoke(Native Method)
 at java.lang.reflect.Method.invoke(Method.java:372)
 at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:905)
 at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:700)

我正在使用android studio 3.0.1,gradle:3.0.1

1 个答案:

答案 0 :(得分:0)

尝试在build.gradle

中添加此内容
sourceSets.main.jniLibs.srcDirs = ['src/main/jniLibs']

或将以下内容添加到android块中:

sourceSets {
    main {
        jniLibs.srcDirs = ['src/main/jniLibs']
    }
}

当读取默认的jniLibs路径时,Gradle可能会出现问题,只需将其隐藏。

sourceSets.main.jni.srcDirs无效,因为它定义了jni source,就像cpp源文件夹一样。

异常堆栈 nativeLibraryDirectories = [/ vendor / lib,/ system / lib]]] 表明系统根本没有检测到您的lib。要验证它,请确定您的apk,看看是否有/lib文件夹和*.so