Android JNI 编译正确 但是提示程序有错误无法运行 而且还看不到任何错误提示 的解决方法
2013-09-11 14:33
417 查看
前几篇中一直在通过Android做JNI调用,关于JNI的配置请见:http://blog.csdn.net/watkinsong/article/details/9849973
但是前一段时间就遇到了整个工程编译都没有问题,但是没有办法运行的问题,编译结果提示如下:
Your Project contains error(s), please fix them before running your application.
但是,整个工程的编译是没有问题的。
查了很多资料,网上大部分都说是证书过期,但是貌似我这里不适用,也按照网上说的做了,没效果,而且证书过期需要一年的时间,我才搞android不到两个星期。
14:15:00 **** Auto Build of configuration Default for project IBMFaceDetectDemo ****
"D:\\WeiSONG\\sdk\\Android\\android-ndk-r9\\ndk-build.cmd" -j2
Android NDK: WARNING: APP_PLATFORM android-18 is larger than android:minSdkVersion 9 in ./AndroidManifest.xml
"Compile++ thumb : Canny <= Canny.cpp
"Compile++ thumb : Canny <= Canny.cpp
Install : libnative_camera_r2.2.0.so => libs/armeabi-v7a/libnative_camera_r2.2.0.so
Install : libnative_camera_r2.3.3.so => libs/armeabi-v7a/libnative_camera_r2.3.3.so
Install : libnative_camera_r3.0.1.so => libs/armeabi-v7a/libnative_camera_r3.0.1.so
Install : libnative_camera_r4.0.0.so => libs/armeabi-v7a/libnative_camera_r4.0.0.so
Install : libnative_camera_r4.0.3.so => libs/armeabi-v7a/libnative_camera_r4.0.3.so
SharedLibrary : libCanny.so
Install : libnative_camera_r2.2.0.so => libs/armeabi/libnative_camera_r2.2.0.so
Install : libnative_camera_r3.0.1.so => libs/armeabi/libnative_camera_r3.0.1.so
Install : libnative_camera_r2.3.3.so => libs/armeabi/libnative_camera_r2.3.3.so
Install : libnative_camera_r4.0.0.so => libs/armeabi/libnative_camera_r4.0.0.so
Install : libnative_camera_r4.0.3.so => libs/armeabi/libnative_camera_r4.0.3.so
SharedLibrary : libCanny.so
Install : libCanny.so => libs/armeabi/libCanny.so
Install : libCanny.so => libs/armeabi-v7a/libCanny.so
14:15:03 Build Finished (took 2s.670ms)
可以看到,整个程序编译完全正常,而且整个项目没有任何错误提示,红叉啊什么的
上图中可以看到整个项目没有任何错误提示。
那么?项目的问题在哪里呢?仔细看看编译的过程中,闪过了一些红的错误提示,但是由于安装了ADT的原因,这个时候的输出都是编译的信息,需要切换到Eclipse系统的输出看看错误,我就是因为才接触Eclipse不知道中间还输出了其他的错误信息
切换到Eclipse的控制台输出,会看到下面的错误提示:
[2013-09-11 14:09:54 - IBMFaceDetectDemo] Error generating final archive: Found duplicate file for APK: lib/armeabi/libnative_camera_r2.2.0.so
Origin 1: D:\workspace\IBMFaceDetectDemo\libs\armeabi\libnative_camera_r2.2.0.so
Origin 2: D:\WeiSONG\sdk\opencv2.4android\OpenCV-2.4.0\libs\armeabi\libnative_camera_r2.2.0.so
[2013-09-11 14:15:50 - IBMFaceDetectDemo] Error generating final archive: Found duplicate file for APK: lib/armeabi/libnative_camera_r2.2.0.so
Origin 1: D:\workspace\IBMFaceDetectDemo\libs\armeabi\libnative_camera_r2.2.0.so
Origin 2: D:\WeiSONG\sdk\opencv2.4android\OpenCV-2.4.0\libs\armeabi\libnative_camera_r2.2.0.so
这里提示了动态链接库重复了,再仔细看看我们的工程目录:
NDK 在编译的时候根据Opencv.mk的参数设置,讲那几个关于摄像头的动态链接库复制到libs文件夹里面了,然后我们的工程还引用了Opencv2.4的这个lib库,所以造成了本工程的lib和opencv2.4的外部lib冲突了。
看一下我们原来的Android.mk文件:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
OPENCV_LIB_TYPE:=STATIC
ifeq ("$(wildcard $(OPENCV_MK_PATH))","")
#try to load OpenCV.mk from default install location
include D:/WeiSONG/sdk/opencv2.4android/OpenCV-2.4.0/share/OpenCV/OpenCV.mk
else
include $(OPENCV_MK_PATH)
endif
LOCAL_MODULE := Canny
LOCAL_SRC_FILES := Canny.cpp
include $(BUILD_SHARED_LIBRARY)
这个mk文件中,没有定义 下面这句话,所以会导致opencv.mk在编译文件的时候讲动态链接库复制了
OPENCV_CAMERA_MODULES:=off
看一下opencv.mk的内容(部分):
ifeq (${OPENCV_CAMERA_MODULES},off)
OPENCV_CAMERA_MODULES:=
else
ifeq ($(TARGET_ARCH_ABI),armeabi)
OPENCV_CAMERA_MODULES:= native_camera_r2.2.0 native_camera_r2.3.3 native_camera_r3.0.1 native_camera_r4.0.0 native_camera_r4.0.3
endif
ifeq ($(TARGET_ARCH_ABI),armeabi-v7a)
OPENCV_CAMERA_MODULES:= native_camera_r2.2.0 native_camera_r2.3.3 native_camera_r3.0.1 native_camera_r4.0.0 native_camera_r4.0.3
endif
ifeq ($(TARGET_ARCH_ABI),x86)
OPENCV_CAMERA_MODULES:= native_camera_r2.3.3 native_camera_r3.0.1 native_camera_r4.0.3
endif
endif
可以看到如果不定义OPENCV_CAMERA_MODULES
这个变量的话,会自动复制一些摄像头相关的链接库。
所以在我们的工程的Android.mk中,应该添加上
OPENCV_CAMERA_MODULES:=off这一句,然后就可以正常的运行你的程序了,在libs文件夹中也不会看到摄像头相关的链接库了。
新的Android.mk代码:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
OPENCV_CAMERA_MODULES:=off
OPENCV_LIB_TYPE:=STATIC
ifeq ("$(wildcard $(OPENCV_MK_PATH))","")
#try to load OpenCV.mk from default install location
include D:/WeiSONG/sdk/opencv2.4android/OpenCV-2.4.0/share/OpenCV/OpenCV.mk
else
include $(OPENCV_MK_PATH)
endif
LOCAL_MODULE := Canny
LOCAL_SRC_FILES := Canny.cpp
include $(BUILD_SHARED_LIBRARY)
然后在编译信息提示中,也不会看到像原来的提示信心那么多了:
14:30:41 **** Auto Build of configuration Default for project IBMFaceDetectDemo ****
"D:\\WeiSONG\\sdk\\Android\\android-ndk-r9\\ndk-build.cmd" -j2
Android NDK: WARNING: APP_PLATFORM android-18 is larger than android:minSdkVersion 9 in ./AndroidManifest.xml
"Compile++ thumb : Canny <= Canny.cpp
"Compile++ thumb : Canny <= Canny.cpp
SharedLibrary : libCanny.so
SharedLibrary : libCanny.so
Install : libCanny.so => libs/armeabi-v7a/libCanny.so
Install : libCanny.so => libs/armeabi/libCanny.so
14:30:43 Build Finished (took 2s.195ms)
但是前一段时间就遇到了整个工程编译都没有问题,但是没有办法运行的问题,编译结果提示如下:
Your Project contains error(s), please fix them before running your application.
但是,整个工程的编译是没有问题的。
查了很多资料,网上大部分都说是证书过期,但是貌似我这里不适用,也按照网上说的做了,没效果,而且证书过期需要一年的时间,我才搞android不到两个星期。
14:15:00 **** Auto Build of configuration Default for project IBMFaceDetectDemo ****
"D:\\WeiSONG\\sdk\\Android\\android-ndk-r9\\ndk-build.cmd" -j2
Android NDK: WARNING: APP_PLATFORM android-18 is larger than android:minSdkVersion 9 in ./AndroidManifest.xml
"Compile++ thumb : Canny <= Canny.cpp
"Compile++ thumb : Canny <= Canny.cpp
Install : libnative_camera_r2.2.0.so => libs/armeabi-v7a/libnative_camera_r2.2.0.so
Install : libnative_camera_r2.3.3.so => libs/armeabi-v7a/libnative_camera_r2.3.3.so
Install : libnative_camera_r3.0.1.so => libs/armeabi-v7a/libnative_camera_r3.0.1.so
Install : libnative_camera_r4.0.0.so => libs/armeabi-v7a/libnative_camera_r4.0.0.so
Install : libnative_camera_r4.0.3.so => libs/armeabi-v7a/libnative_camera_r4.0.3.so
SharedLibrary : libCanny.so
Install : libnative_camera_r2.2.0.so => libs/armeabi/libnative_camera_r2.2.0.so
Install : libnative_camera_r3.0.1.so => libs/armeabi/libnative_camera_r3.0.1.so
Install : libnative_camera_r2.3.3.so => libs/armeabi/libnative_camera_r2.3.3.so
Install : libnative_camera_r4.0.0.so => libs/armeabi/libnative_camera_r4.0.0.so
Install : libnative_camera_r4.0.3.so => libs/armeabi/libnative_camera_r4.0.3.so
SharedLibrary : libCanny.so
Install : libCanny.so => libs/armeabi/libCanny.so
Install : libCanny.so => libs/armeabi-v7a/libCanny.so
14:15:03 Build Finished (took 2s.670ms)
可以看到,整个程序编译完全正常,而且整个项目没有任何错误提示,红叉啊什么的
上图中可以看到整个项目没有任何错误提示。
那么?项目的问题在哪里呢?仔细看看编译的过程中,闪过了一些红的错误提示,但是由于安装了ADT的原因,这个时候的输出都是编译的信息,需要切换到Eclipse系统的输出看看错误,我就是因为才接触Eclipse不知道中间还输出了其他的错误信息
切换到Eclipse的控制台输出,会看到下面的错误提示:
[2013-09-11 14:09:54 - IBMFaceDetectDemo] Error generating final archive: Found duplicate file for APK: lib/armeabi/libnative_camera_r2.2.0.so
Origin 1: D:\workspace\IBMFaceDetectDemo\libs\armeabi\libnative_camera_r2.2.0.so
Origin 2: D:\WeiSONG\sdk\opencv2.4android\OpenCV-2.4.0\libs\armeabi\libnative_camera_r2.2.0.so
[2013-09-11 14:15:50 - IBMFaceDetectDemo] Error generating final archive: Found duplicate file for APK: lib/armeabi/libnative_camera_r2.2.0.so
Origin 1: D:\workspace\IBMFaceDetectDemo\libs\armeabi\libnative_camera_r2.2.0.so
Origin 2: D:\WeiSONG\sdk\opencv2.4android\OpenCV-2.4.0\libs\armeabi\libnative_camera_r2.2.0.so
这里提示了动态链接库重复了,再仔细看看我们的工程目录:
NDK 在编译的时候根据Opencv.mk的参数设置,讲那几个关于摄像头的动态链接库复制到libs文件夹里面了,然后我们的工程还引用了Opencv2.4的这个lib库,所以造成了本工程的lib和opencv2.4的外部lib冲突了。
看一下我们原来的Android.mk文件:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
OPENCV_LIB_TYPE:=STATIC
ifeq ("$(wildcard $(OPENCV_MK_PATH))","")
#try to load OpenCV.mk from default install location
include D:/WeiSONG/sdk/opencv2.4android/OpenCV-2.4.0/share/OpenCV/OpenCV.mk
else
include $(OPENCV_MK_PATH)
endif
LOCAL_MODULE := Canny
LOCAL_SRC_FILES := Canny.cpp
include $(BUILD_SHARED_LIBRARY)
这个mk文件中,没有定义 下面这句话,所以会导致opencv.mk在编译文件的时候讲动态链接库复制了
OPENCV_CAMERA_MODULES:=off
看一下opencv.mk的内容(部分):
ifeq (${OPENCV_CAMERA_MODULES},off)
OPENCV_CAMERA_MODULES:=
else
ifeq ($(TARGET_ARCH_ABI),armeabi)
OPENCV_CAMERA_MODULES:= native_camera_r2.2.0 native_camera_r2.3.3 native_camera_r3.0.1 native_camera_r4.0.0 native_camera_r4.0.3
endif
ifeq ($(TARGET_ARCH_ABI),armeabi-v7a)
OPENCV_CAMERA_MODULES:= native_camera_r2.2.0 native_camera_r2.3.3 native_camera_r3.0.1 native_camera_r4.0.0 native_camera_r4.0.3
endif
ifeq ($(TARGET_ARCH_ABI),x86)
OPENCV_CAMERA_MODULES:= native_camera_r2.3.3 native_camera_r3.0.1 native_camera_r4.0.3
endif
endif
可以看到如果不定义OPENCV_CAMERA_MODULES
这个变量的话,会自动复制一些摄像头相关的链接库。
所以在我们的工程的Android.mk中,应该添加上
OPENCV_CAMERA_MODULES:=off这一句,然后就可以正常的运行你的程序了,在libs文件夹中也不会看到摄像头相关的链接库了。
新的Android.mk代码:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
OPENCV_CAMERA_MODULES:=off
OPENCV_LIB_TYPE:=STATIC
ifeq ("$(wildcard $(OPENCV_MK_PATH))","")
#try to load OpenCV.mk from default install location
include D:/WeiSONG/sdk/opencv2.4android/OpenCV-2.4.0/share/OpenCV/OpenCV.mk
else
include $(OPENCV_MK_PATH)
endif
LOCAL_MODULE := Canny
LOCAL_SRC_FILES := Canny.cpp
include $(BUILD_SHARED_LIBRARY)
然后在编译信息提示中,也不会看到像原来的提示信心那么多了:
14:30:41 **** Auto Build of configuration Default for project IBMFaceDetectDemo ****
"D:\\WeiSONG\\sdk\\Android\\android-ndk-r9\\ndk-build.cmd" -j2
Android NDK: WARNING: APP_PLATFORM android-18 is larger than android:minSdkVersion 9 in ./AndroidManifest.xml
"Compile++ thumb : Canny <= Canny.cpp
"Compile++ thumb : Canny <= Canny.cpp
SharedLibrary : libCanny.so
SharedLibrary : libCanny.so
Install : libCanny.so => libs/armeabi-v7a/libCanny.so
Install : libCanny.so => libs/armeabi/libCanny.so
14:30:43 Build Finished (took 2s.195ms)
相关文章推荐
- Android JNI 编译正确 但是提示程序有错误无法运行 而且还看不到任何错误提示 的解决方法
- VC编译程序,运行时提示运行错误“由于应用程序的配置不正确,……”解决方法
- win7(32 bit) + IE8 环境,IE8无法弹窗(错误提示:“此网页上的错误可能会使它无法正确运行”),有关的系统注册信息损坏——解决方法
- 初学OpenCV3,运行编程入门上读取并播放视频的原版程序,编译通过但是没有任何输出,已按网上博主各种方法试,还是没有结果,大家看怎么解决?
- 关于androidstuio运行程序遇到 Error:(11, 8) 错误: 无法访问HttpEntity 找不到org.apache.http.HttpEntity的类文件解决方法
- 【共享】解决“无法显示进程。没有正确安装调试器。请运行安装程序安装或修复调试器。”错误的方法。
- 使用wxWidgets编译的Windows Mobile程序运行时提示“SHCreateMenuBar failed”错误的解决方法
- VC编译程序,运行时提示“由于应用程序的配置不正确,……”解决方法
- vs编译程序在Win7下提示无法运行解决方法
- win10下Java程序在cmd中能够编译却无法运行的解决方法
- vs2005 编译程序无法运行解决方法
- win7 64位平台编译的程序在XP 32位平台无法运行的解决方法
- mac 下 使用 java运行 class 文件 总是提示 “错误: 找不到或无法加载主类”的解决方法
- 检测到指定的WEB服务器运行的不是ASP.NET 1.1版,您无法运行ASP.NET应用程序或服务和创建ASP.NET程序时候发生错误 HTTP/1.0 500 Server Error的解决方法
- 在ubuntu下安装任何软件时都提示软件包 flash-plugin 需要重新安装,但是我无法找到相应的安装文件的错误的解决办法。
- 解决VS2008编译的程序在某些机器上运行提示“由于应用程序配置不正确,应用程序未能启动”的问题
- 运行VS2013编译成功后出现:无法启动程序“.exe” 系统找不到指定文件的问题的解决方法
- (ZT) 解决VS2008编译的程序在某些机器上运行提示“由于应用程序配置不正确,应用程序未能启动”的问题
- VS2015 C++编译失败,提示link1171,无法加载mspdb140.dll错误解决方法!
- XE2编译的程序无法在windows 2000 windows98上运行的错误解决