我有一个已发布的应用程序java.lang.UnsatisfiedLinkError
在某些设备上报告崩溃。更准确地说,应用程序在启动时崩溃并显示以下日志消息:
Caused by: java.lang.UnsatisfiedLinkError: Couldn't load qcc: findLibrary returned null
实际的崩溃在System.loadLibrary("qcc");
指令中,因此应用程序无法确定找到库。
问题是我自己无法重现该问题。实际上,同一个 apk 在许多不同的设备和版本上都能完美运行。
该应用程序使用由第三方编写和编译的两个 C 库。它们是使用arm-linux-androideabi-4.6
工具链编译的,我将它们集成到我的项目中,nkd-build
并使用以下Android.mk
文件运行:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE := libqcc
LOCAL_SRC_FILES := qcc/libqcc.so
include $(PREBUILT_SHARED_LIBRARY)
include $(CLEAR_VARS)
LOCAL_MODULE := libqpe
LOCAL_SRC_FILES := qpe/libqpe.so
include $(PREBUILT_SHARED_LIBRARY)
该错误正在不同的设备上报告,但目前它们都是以下 Android 版本之一:2.2、2.2.1 或 2.2.2。
我认为这可能是架构问题或安装过程中的奇怪问题。
有谁知道是什么问题?
更新:
我意识到我可以在 Android 2.2 模拟器中重现该问题。这是我可以从 logcat 收集的额外信息。
11:14:59.962 I/dalvikvm( 287): Unable to dlopen(/data/data/.../lib/libqcc.so): Cannot load library: link_image[1995]: failed to link libqcc.so
11:14:59.962 W/dalvikvm( 287): Exception Ljava/lang/UnsatisfiedLinkError;