【问题标题】:Android NDK - Library not foundAndroid NDK - 找不到库
【发布时间】:2015-09-24 17:24:35
【问题描述】:

我使用 Android Studio 和 Android NDK。 我的文件夹“src/main/jni”包含以下文件:

  • Android.mk
  • Application.mk
  • HelloWorld.cpp

应用程序.mk APP_ABI := all

Android.mk

LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE := HelloWorld
LOCAL_SRC_FILES := HelloWorld.cpp
include $(BUILD_SHARED_LIBRARY)

在我的 Java 代码中,我加载了库:

static{
    System.load("HelloWorld");
}

我运行 ndk-build 如下,它运行没有错误:ndk-build -C src/main

build.gradle 包含:

sourceSets.main {
jniLibs.srcDirs 'src/main/libs'
jni.srcDirs = [] //disable automatic ndk-build call
}

libHelloWorld.so 编译后复制到文件夹:app\src\main\libs\arm*\

app-debug.apk 的根目录包含一个 lib 目录。 libHelloWorld.so 存在于所有子目录中(lib\arm*)

当我在 LG Nexus 4 设备上部署和调试应用程序时,我收到以下错误:

9-24 18:50:51.486  20352-20352/ndk.tests.firstndk E/art﹕ dlopen("HelloWorld", RTLD_LAZY) failed: dlopen failed: library "HelloWorld" not found
09-24 18:50:51.489  20352-20352/ndk.tests.firstndk D/AndroidRuntime﹕ Shutting down VM
09-24 18:50:51.491  20352-20352/ndk.tests.firstndk E/AndroidRuntime﹕ FATAL EXCEPTION: main
Process: ndk.tests.firstndk, PID: 20352
java.lang.UnsatisfiedLinkError: dlopen failed: library "HelloWorld" not found
at java.lang.Runtime.load(Runtime.java:331)
at java.lang.System.load(System.java:981)
at ndk.tests.firstndk.MainActivity.<clinit>(MainActivity.java:11)
at java.lang.reflect.Constructor.newInstance(Native Method)

您能帮忙解决这个问题吗?为什么我的本机库无法加载?我的配置有什么问题?

【问题讨论】:

    标签: android android-ndk


    【解决方案1】:

    尝试:

    static{
        System.loadLibrary("HelloWorld");
    }
    

    【讨论】:

    • 谢谢,这行得通!这么小的错误浪费了这么长时间......非常感谢!
    猜你喜欢
    • 1970-01-01
    • 2017-09-19
    • 2012-09-11
    • 2014-05-30
    • 2021-11-26
    • 2019-09-11
    • 2012-09-26
    • 2012-04-16
    • 1970-01-01
    相关资源
    最近更新 更多