Android 4.2 ndk:库加载崩溃:load_library(linker.cpp:750) || soinfo_link_image || libhoudini.so ||打开简历
Android 4.2 ndk: library loading crash: load_library(linker.cpp:750) || soinfo_link_image || libhoudini.so || opencv
我正在使用包含 opencv 的本机库。
该库在所有设备和模拟器中构建良好并且运行良好,但在 Android 4.2 上则不然。它在 System.loadLibrary("mylib");
.
崩溃
该库是为 armeabi-v7a armeabi x86 mips 构建的(我在 jnilibs 文件夹中看到生成了所有 so 文件)
我被这个错误困住了,因为我在互联网上找不到任何可以解释我的问题的答案。
Cannot load library: soinfo_link_image(linker.cpp:1635): could not load library "libopencv_java.so"
,日志跟踪:
1755-1755/com.ex.app E/AndroidRuntime﹕ FATAL EXCEPTION: main
java.lang.UnsatisfiedLinkError: Cannot load library: soinfo_link_image(linker.cpp:1635): could not load library "libopencv_java.so" needed by "libmylib.so"; caused by load_library(linker.cpp:745): library "libopencv_java.so" not found
at java.lang.Runtime.loadLibrary(Runtime.java:371)
at java.lang.System.loadLibrary(System.java:535)
at com.ex.app.core.MyApplication.initVippAsync(MyApplication.java:198)
at com.ex.app.core.MyApplication.onCreate(MyApplication.java:100)
at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:1000)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4391)
at android.app.ActivityThread.access00(ActivityThread.java:141)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1294)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5039)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
at dalvik.system.NativeStart.main(Native Method)
Android.mk:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
OPENCV_INSTALL_MODULES:=on
include /Users/ahmed/Documents/openCv4android/OpenCV-2.4.10-android-sdk/sdk/native/jni/OpenCV.mk
LOCAL_MODULE := mylib
LOCAL_LDLIBS += -llog -ldl
LOCAL_SRC_FILES := myFile.c
include $(BUILD_SHARED_LIBRARY)
Application.mk:
APP_ABI := armeabi-v7a armeabi x86 mips
APP_PLATFORM := android-16
我找到了答案。分为两步:
1/ 如果您使用的是模拟器 Genymotion,Android 4.2.2,您将缺少库,这是由 Genimotion 的更新之一引起的。参见 this。
解决方案 :
(1)> 下载以下 zip 文件:here。
(2)> 只需将其拖放到您的模拟器中即可。
(3)> 重启你的模拟器。
2/ 在 Android 4.2 中,OS 无法找到 apk 中提供的 jni 库的路径。例如,在我的例子中,我使用的是一个使用 openCV 库的 jni 库。
对于每个设备和 android 版本调用 System.loadLibrary("mylib");
运行良好并且 mylib
自动加载 opencv 库。
对于 Android 4.2,正如@Chris 在他的评论中所说,我明确加载了 openCV,所以:
System.loadLibrary("opencv_java");
System.loadLibrary("mylib");
我正在使用包含 opencv 的本机库。
该库在所有设备和模拟器中构建良好并且运行良好,但在 Android 4.2 上则不然。它在 System.loadLibrary("mylib");
.
该库是为 armeabi-v7a armeabi x86 mips 构建的(我在 jnilibs 文件夹中看到生成了所有 so 文件)
我被这个错误困住了,因为我在互联网上找不到任何可以解释我的问题的答案。
Cannot load library: soinfo_link_image(linker.cpp:1635): could not load library "libopencv_java.so"
,日志跟踪:
1755-1755/com.ex.app E/AndroidRuntime﹕ FATAL EXCEPTION: main
java.lang.UnsatisfiedLinkError: Cannot load library: soinfo_link_image(linker.cpp:1635): could not load library "libopencv_java.so" needed by "libmylib.so"; caused by load_library(linker.cpp:745): library "libopencv_java.so" not found
at java.lang.Runtime.loadLibrary(Runtime.java:371)
at java.lang.System.loadLibrary(System.java:535)
at com.ex.app.core.MyApplication.initVippAsync(MyApplication.java:198)
at com.ex.app.core.MyApplication.onCreate(MyApplication.java:100)
at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:1000)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4391)
at android.app.ActivityThread.access00(ActivityThread.java:141)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1294)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5039)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
at dalvik.system.NativeStart.main(Native Method)
Android.mk:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
OPENCV_INSTALL_MODULES:=on
include /Users/ahmed/Documents/openCv4android/OpenCV-2.4.10-android-sdk/sdk/native/jni/OpenCV.mk
LOCAL_MODULE := mylib
LOCAL_LDLIBS += -llog -ldl
LOCAL_SRC_FILES := myFile.c
include $(BUILD_SHARED_LIBRARY)
Application.mk:
APP_ABI := armeabi-v7a armeabi x86 mips
APP_PLATFORM := android-16
我找到了答案。分为两步:
1/ 如果您使用的是模拟器 Genymotion,Android 4.2.2,您将缺少库,这是由 Genimotion 的更新之一引起的。参见 this。 解决方案 : (1)> 下载以下 zip 文件:here。 (2)> 只需将其拖放到您的模拟器中即可。 (3)> 重启你的模拟器。
2/ 在 Android 4.2 中,OS 无法找到 apk 中提供的 jni 库的路径。例如,在我的例子中,我使用的是一个使用 openCV 库的 jni 库。
对于每个设备和 android 版本调用 System.loadLibrary("mylib");
运行良好并且 mylib
自动加载 opencv 库。
对于 Android 4.2,正如@Chris 在他的评论中所说,我明确加载了 openCV,所以:
System.loadLibrary("opencv_java");
System.loadLibrary("mylib");