UnsatisfiedLinkError、couldn't find "xxx.so"
2017-09-04 19:11
1101 查看
相关环境仅作参考
从日志中看到虚拟机加载了/lib/arm64 和 /lib/arm64-v8a,没有/lib/armeabi-v7a,不科学啊
对生成的apk分析
发现存在多个cpu兼容目录,而我们只兼容armeabi-v7a,根据apk发现其中的libsophix是项目中的一个依赖其包含了多个兼容库被一起打包到了apk中,这里根据项目的情况只想要一个兼容库。
然后再次分析apk,其仅兼容armeabi-v7a了:
虚拟机加载so库时,如果发现arm64-v8a目录,就只加载arm64-v8a目录(但是为啥还有个arm64目录?)
arm64-v8a中显然没有目标so,所以报错。其实还可以将armeabi-v7a中的so文件copy到arm64-v8a中,但不是个好方法,因为我们的目标是兼容armeabi-v7a,不同的cpu版本有不同的开发接口。
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版本有不同的开发接口。
相关文章推荐
- AndroidStudio打包dalvik.system.PathClassLoader:couldn't find"xxx.so "
- 解决Android 错误 couldn't find "xxx.so" is 32-bit instead of 64-bit
- Android 调用so文件中方法应该注意的 couldn't find "libXXX.so"
- couldn't find "libxxx.so"
- Android6.0 UnsatisfiedLinkError couldn't find "xxx.so"
- couldn't find "libxxx.so"与"libxxx.so" is too small to be an ELF executable解决方法
- java.lang.UnsatisfiedLinkError: No implementation found for int com.xxx.xx中的couldn’t find “XX.so”或loadLibrary("xxx")失败
- android PathClassLoader couldn't find "libxxx.so"
- java.lang.UnsatisfiedLinkError: dalvik.system.PathClassLoader......couldn't find "libweibosdkcore.so
- 开发错误记录13:java.lang.UnsatisfiedLinkError: Couldn't load xxx.so: findLibrary returned null
- /lib/arm64, /vendor/lib64, /system/lib64 couldn't find "libstlport_shared.so"
- [已解决]讯飞集成的时候遇到“组件未安装.(错误码:21002)”,couldn't find "libmsc.so"
- AndroidStudio-/vendor/lib, /system/lib]]] couldn't find "libweibosdkcore.so"
- /lib/arm64, /vendor/lib64, /system/lib64 couldn't find "libstlport_shared.so"
- 加载so库错误问题“couldn't find "libbmob.so"”
- Android Studio 加载 .so库出现couldn't find "*.so"
- couldn't find "libyuv.so
- 找不到so文件java.lang.UnsatisfiedLinkError: dalvik.sys.... couldn't find "libijkffmpeg.so"
- arcgis Android cmake couldn't find "libruntimecore_java.so" 问题解决
- couldn't find "libvinit.so"