运行android本机代码导致java.lang.UnsatifiedLink错误
我有一个带有本机代码的android应用程序,我使用openCV库。在手机上运行应用程序时,一切正常,但当我尝试在平板电脑(联想瑜伽2 pro)上运行应用程序时,遇到以下错误:运行android本机代码导致java.lang.UnsatifiedLink错误,java,android,opencv,android-ndk,opencv4android,Java,Android,Opencv,Android Ndk,Opencv4android,我有一个带有本机代码的android应用程序,我使用openCV库。在手机上运行应用程序时,一切正常,但当我尝试在平板电脑(联想瑜伽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:
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)
有人能帮我解决这个错误吗?或者我做错了什么?您的平板电脑基于Intel Atom CPU。您必须为
APP\u ABI=x86
构建您的本机模块。请注意,您还需要兼容版本的OpenCV
更新:在这种情况下,该应用程序是为x86和ARM构建的。但是应用程序安装程序选择了错误的子文件夹,可能是因为libs/x86
和libs/armeabi
中列出的文件名。对于具有非平凡本机组件的应用程序,可靠而高效的方法是。我有一个华硕Zenfone 5(使用x86 ABI),我也遇到了同样的问题。
显然问题出在OpenCV 2.x版本上。
开始使用OpenCV 3.x版本,问题就会得到解决
OpenCV 3.x版本有更多的ABI选项,例如:
arm64v8a
arm
armv7a
mips
mips64
x86
x86-64
您可以找到3.x版本
希望有帮助 我也这么想,我检查了APP_ABI,但它的设置如下:APP_ABI:=armeabi armeabi-v7a x86 mips,所以应该可以。你说的兼容版OpenCV是什么意思?因为当我下载android版openCV时,没有选择处理器类型的选项。你使用openCV的共享版本还是静态版本?在我的项目中,我有目录库,其中包含不同处理器类型的.so和.a库的子文件夹(这些子文件夹来自下载的opencv project for android,文件夹结构为sdk/native/libs)。然后我在eclipse(sdk/java)中链接了opencv android项目。您可以验证eclipse项目的
libs/
文件夹的内容。在C/C++透视图中,您可以看到“二进制文件”选项卡,它将列出您已标记为体系结构(x86/arm/无论什么)的so
文件。但您还应该检查设备上实际安装了哪些文件。我如何检查设备上安装了哪些文件?但要运行应用程序,我必须下载opencv manager应用程序,并且该应用程序正在运行(不会崩溃)所以这有点奇怪。请看:e\u machine=40
的意思是EM\u ARM
。
arm64v8a
arm
armv7a
mips
mips64
x86
x86-64