java.lang.UnsatisfiedLinkError:dlopen 失败:

Khy*_*oda 5 android android-ndk android-studio

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

案例:1我试图将我的 .so 放入 src/main/jniLibs 中,并在我添加了以下行的 gradle 文件中,但出现了相同的错误。

 android {
     sourceSets.main.jni.srcDirs = []
}
Run Code Online (Sandbox Code Playgroud)

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

defaultConfig {
 ndk {
        abiFilters "armeabi", "armeabi-v7a", "x86", "mips"
  }
   }
Run Code Online (Sandbox Code Playgroud)

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

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

        }
    }
}
Run Code Online (Sandbox Code Playgroud)

我的项目架构

错误代码:

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)
Run Code Online (Sandbox Code Playgroud)

我使用的是android studio 3.0.1,gradle:3.0.1

sak*_*kiM 5

尝试将其添加到build.gradle

sourceSets.main.jniLibs.srcDirs = ['src/main/jniLibs']
Run Code Online (Sandbox Code Playgroud)

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

sourceSets {
    main {
        jniLibs.srcDirs = ['src/main/jniLibs']
    }
}
Run Code Online (Sandbox Code Playgroud)

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

sourceSets.main.jni.srcDirs不起作用,因为它定义了jni source,如 cpp 源文件文件夹。

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