简体   繁体   English

找不到Android中的本机OpenCV UnsatisfiedLinkError libopencv_java.so

[英]Native OpenCV in Android UnsatisfiedLinkError libopencv_java.so not found

I've seen similar posts but none were giving correct answers. 我见过类似的帖子,但是都没有给出正确的答案。

Setup: 设定:

Linux Ubuntu 14.04
Android NDK r8e
Boost 1.53
OpenCV 2.4.9

While compiling I got this warning: 编译时收到以下警告:

Compile++ thumb  : usit <= wahet.cpp
SharedLibrary  : libusit.so
/home/tassilo/android-ndks/android-ndk-r8e/toolchains/arm-linux-androideabi-4.6/prebuilt/linux-x86_64/bin/../lib/gcc/arm-linux-androideabi/4.6/../../../../arm-linux-androideabi/bin/ld: warning: hidden symbol '__aeabi_atexit' in /home/tassilo/android-ndks/android-ndk-r8e/sources/cxx-stl/gnu-libstdc++/4.6/libs/armeabi-v7a/libgnustl_static.a(atexit_arm.o) is referenced by DSO jni/opencv/sdk/native/jni/../libs/armeabi-v7a/libopencv_java.so
Install        : libusit.so => libs/armeabi-v7a/libusit.so

I am not yet trying to call my C++ code, all I am doing is creating the library which results in this error: 我尚未尝试调用我的C ++代码,我正在做的只是创建导致此错误的库:

09-16 14:34:59.189: V/IRISREC(654): Native code library failed to load.
09-16 14:34:59.189: V/IRISREC(654): java.lang.UnsatisfiedLinkError: Cannot load library: link_image[1936]:    36 could not load needed library 'libopencv_java.so' for 'libusit.so' (load_library[1091]: Library 'libopencv_java.so' not found)

Here is my Android.mk 这是我的Android.mk

LOCAL_PATH := $(call my-dir)
NDK_ROOT := /home/tassilo/android-ndks/android-ndk-r8e


include $(CLEAR_VARS)

include ./jni/opencv/sdk/native/jni/OpenCV.mk

LOCAL_MODULE           := usit
LOCAL_SRC_FILES        := wahet.cpp

LOCAL_C_INCLUDES:= ./jni/opencv/sdk/native/jni/include
LOCAL_CFLAGS += -I$(LOCAL_PATH)/boost/include/boost-1_53
LOCAL_LDLIBS += -L$(LOCAL_PATH)/boost/lib/ -lboost_system-gcc-mt-1_53 -lboost_regex-gcc-mt-1_53 -lboost_filesystem-gcc-mt-1_53 -lboost_date_time-gcc-mt-1_53 \
-L$(NDK_ROOT)/sources/cxx-stl/gnu-libstdc++/4.6/libs/armeabi \
-lgnustl_static \
-L$(SYSROOT)/usr/lib -llog

include $(BUILD_SHARED_LIBRARY)

Application.mk Application.mk

APP_PLATFORM          := android-8
APP_ABI               := armeabi-v7a
APP_OPTIM             := debug
NDK_DEBUG             := 1

NDK_TOOLCHAIN_VERSION := 4.6
APP_STL               := gnustl_static
APP_CPPFLAGS          := -fexceptions -frtti

and the library load in my MainAcitvity.java 并在MainAcitvity.java中加载库

static {
    try {
        System.loadLibrary("usit");
    } catch (UnsatisfiedLinkError e) {
        Log.v(TAG, "Native code library failed to load.\n" + e);
    } catch (Exception e) {
        Log.v(TAG, "Exception: " + e);
    }
}

So the error is thrown in my first catch block. 因此,在我的第一个catch块中引发了错误。 The need library files are in my folder 需要库文件在我的文件夹中

./jni/opencv/sdk/native/libs/ -armeabi/ -armeabi-v7a etc.

I am failing around with all this stuff since several days.. Any help is appreciated. 自几天以来,我一直无法使用所有这些东西。

Regarding hidden symbol '__aeabi_atexit' , the answer at opencv.org suggests to use gnustl_shared instead of gnustl_static . 关于hidden symbol '__aeabi_atexit'opencv.org答案建议使用gnustl_shared而不是gnustl_static

This fit my personal experience with opencv_java, and means that the Java code must change accordingly: 这符合我对opencv_java的个人经验,这意味着Java代码必须相应地更改:

static {
    try {
        System.loadLibrary("gnustl_shared"); // added
        System.loadLibrary("opencv_java");
        System.loadLibrary("usit");
    } catch (UnsatisfiedLinkError e) {
        Log.v(TAG, "Native code library failed to load.\n" + e);
    } catch (Exception e) {
        Log.v(TAG, "Exception: " + e);
    }
}

Android.mk Android.mk

LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)

OPENCV_INSTALL_MODULES:=on
include ./jni/opencv/sdk/native/jni/OpenCV.mk

LOCAL_MODULE           := usit
LOCAL_SRC_FILES        := wahet.cpp

LOCAL_C_INCLUDES := \
  $(LOCAL_PATH)/opencv/sdk/native/jni/include \
  $(LOCAL_PATH)/boost/include/boost-1_53

LOCAL_LDLIBS += -L$(LOCAL_PATH)/boost/lib/ \
  -lboost_system-gcc-mt-1_53 \
  -lboost_regex-gcc-mt-1_53 \
  -lboost_filesystem-gcc-mt-1_53 \
  -lboost_date_time-gcc-mt-1_53 \
  -llog

include $(BUILD_SHARED_LIBRARY)

Application.mk Application.mk

APP_PLATFORM          := android-8
APP_ABI               := armeabi-v7a
APP_OPTIM             := debug
NDK_DEBUG             := 1

NDK_TOOLCHAIN_VERSION := 4.6
APP_STL               := gnustl_shared
APP_CPPFLAGS          := -fexceptions -frtti

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

相关问题 Opencv Android:java.lang.UnsatisfiedLinkError:dlopen失败:无法加载库“libopencv_java.so” - Opencv Android: java.lang.UnsatisfiedLinkError: dlopen failed: could not load library “libopencv_java.so” 无法加载库libopencv_java.so - Could Not Load Library libopencv_java.so UnsitisfiedLinkError:无法加载libopencv_java.so - UnsitisfiedLinkError: Couldn't load libopencv_java.so Android Studio 出现 OpenCV 错误 dlopen 失败:找不到库“libopencv_java3415.so” - Android Studio with OpenCV error dlopen failed: library "libopencv_java3415.so" not found java.lang.UnsatisfiedLinkError:dlopen 失败:找不到库“libopencv_java3.so” - java.lang.UnsatisfiedLinkError: dlopen failed: library “libopencv_java3.so” not found java.lang.UnsatisfiedLinkError:dlopen 失败:找不到库“../../lib/libopencv_core.so” - java.lang.UnsatisfiedLinkError: dlopen failed: library "../../lib/libopencv_core.so" not found Android JavaCV - UnsatisfiedLinkError 并且找不到“libopencv_core.so” - Android JavaCV - UnsatisfiedLinkError and couldn't find "libopencv_core.so" Android:在aarch64平台上找不到armeabi-v7a abi过滤器的libopencv_java3.so - Android : libopencv_java3.so not found for armeabi-v7a abi filter on aarch64 platform 未找到Android UnsatisfiedLinkError本机方法 - Android UnsatisfiedLinkError native method not found UnsatisfiedLinkError:找不到本机方法 - Android - UnsatisfiedLinkError: Native method not found - Android
 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM