您的位置:首页 > 移动开发 > Android开发

UnsatisfiedLinkError、couldn't find "xxx.so"

2017-09-04 19:11 1101 查看
相关环境仅作参考

android 6.0.1
cpu 高通骁龙625 8核 2.0G
gradle 3.3
com.android.tools.build:gradle 2.2.3


错误日志:

java.lang.UnsatisfiedLinkError:
dalvik.system.PathClassLoader[DexPathList[[zip file "/data/app/com.telecom.video-1/base.apk"],
nativeLibraryDirectories=[/data/app/com.telecom.video-1/lib/arm64, /data/app/*packagename*-1/base.apk!/lib/arm64-v8a, /vendor/lib64, /system/lib64]]]
couldn't find "libijkffmpeg.so"


分析

项目目录中的仅配置了armeabi-v7a目录

../lib
|-armeabi-v7a
|-libijkffmpeg.so
|-..


从日志中看到虚拟机加载了/lib/arm64 和 /lib/arm64-v8a,没有/lib/armeabi-v7a,不科学啊

对生成的apk分析

apk中lib/
|-armeabi-v7a
|-libijkffmpeg.so
|-libsophix
|-..
|-x86_64
|-libsophix
|-arm64-v8a
|-libsophix
|-armeabi
|-libsophix
|-x86
|-libsophix


发现存在多个cpu兼容目录,而我们只兼容armeabi-v7a,根据apk发现其中的libsophix是项目中的一个依赖其包含了多个兼容库被一起打包到了apk中,这里根据项目的情况只想要一个兼容库。

解决

我在build.gradle中这样配置,增加了过滤设置cpu兼容:

android {
defaultConfig {
ndk {
abiFilter "armeabi-v7a" //, "armeabi", "x86" 按需设置
}
}
}


然后再次分析apk,其仅兼容armeabi-v7a了:

apk中lib/
|-armeabi-v7a
|-libijkffmpeg.so
|-libsophix.so
|-..


虚拟机加载so库时,如果发现arm64-v8a目录,就只加载arm64-v8a目录(但是为啥还有个arm64目录?)

arm64-v8a中显然没有目标so,所以报错。其实还可以将armeabi-v7a中的so文件copy到arm64-v8a中,但不是个好方法,因为我们的目标是兼容armeabi-v7a,不同的cpu版本有不同的开发接口。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  android gradle so