java - 运行 android native 代码导致 java.lang.UnsatisfiedLinkError

标签 java android opencv android-ndk

我有一个带有 native 代码的 Android 应用程序,我在其中使用了 openCV 库。在手机上运行该应用程序时一切正常,但是当我尝试在平板电脑(Lenovo yoga 2 pro)上运行它时,我遇到了这个错误:

01-03 11:53:13.007: E/AndroidRuntime(25632): FATAL EXCEPTION: main
01-03 11:53:13.007: E/AndroidRuntime(25632): Process: <appname>, PID: 25632
01-03 11:53:13.007: E/AndroidRuntime(25632): java.lang.UnsatisfiedLinkError: dlopen failed: "/data/app-lib/<appname>/libnative_module.so" has unexpected e_machine: 40
01-03 11:53:13.007: E/AndroidRuntime(25632):    at java.lang.Runtime.loadLibrary(Runtime.java:364)
01-03 11:53:13.007: E/AndroidRuntime(25632):    at java.lang.System.loadLibrary(System.java:526)
01-03 11:53:13.007: E/AndroidRuntime(25632):    at <appname>.SplashActivity$1.onManagerConnected(SplashActivity.java:35)
01-03 11:53:13.007: E/AndroidRuntime(25632):    at org.opencv.android.AsyncServiceHelper$1.onServiceConnected(AsyncServiceHelper.java:318)
01-03 11:53:13.007: E/AndroidRuntime(25632):    at android.app.LoadedApk$ServiceDispatcher.doConnected(LoadedApk.java:1127)
01-03 11:53:13.007: E/AndroidRuntime(25632):    at android.app.LoadedApk$ServiceDispatcher$RunConnection.run(LoadedApk.java:1144)
01-03 11:53:13.007: E/AndroidRuntime(25632):    at android.os.Handler.handleCallback(Handler.java:733)
01-03 11:53:13.007: E/AndroidRuntime(25632):    at android.os.Handler.dispatchMessage(Handler.java:95)
01-03 11:53:13.007: E/AndroidRuntime(25632):    at android.os.Looper.loop(Looper.java:149)
01-03 11:53:13.007: E/AndroidRuntime(25632):    at android.app.ActivityThread.main(ActivityThread.java:5283)
01-03 11:53:13.007: E/AndroidRuntime(25632):    at java.lang.reflect.Method.invokeNative(Native Method)
01-03 11:53:13.007: E/AndroidRuntime(25632):    at java.lang.reflect.Method.invoke(Method.java:515)
01-03 11:53:13.007: E/AndroidRuntime(25632):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:825)
01-03 11:53:13.007: E/AndroidRuntime(25632):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:641)
01-03 11:53:13.007: E/AndroidRuntime(25632):    at dalvik.system.NativeStart.main(Native Method)

这是在 SplashActivity 的第 45 行:

System.loadLibrary("native_module");

有人可以帮我解决这个错误吗?或者我做错了什么?

最佳答案

您的平板电脑基于 Intel Atom CPU。您必须为 APP_ABI=x86 构建您的 native_module。请注意,您还需要兼容版本的 OpenCV。

更新:在这种特殊情况下,该应用程序是为 x86 和 ARM 构建的。但是应用程序安装程序选择了错误的子文件夹,可能是因为 libs/x86libs/armeabi did not exactly match 中列出的文件名。对于具有重要原生组件的应用程序,可靠且高效的方法是 upload separate APKs to PlayStore

关于java - 运行 android native 代码导致 java.lang.UnsatisfiedLinkError,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27754468/

相关文章:

Java Regex 捕获多个匹配项

Java JSON对象解析

python - 使用某些 OpenCV 函数时出现段错误

c++ - cvBlob/Opencv : Why is my output variable empty?

c - OpenCV 根据像素值调整大小和裁剪图像

java - 如何让 Java 在我的场景中检测按键?

java - 在 tomcat 的 Web 应用程序中启用 SSL(双向握手)到外部应用程序

android - 如何将我的 makeSceneTransitionAnimation 变成圆形而不是矩形?

android - 将 android/java 移植到 ios/objective c 的好书

java - 号码格式错误