[TOC]
作者:Zyao89;转载请保留此行,谢谢;
解决问题:
1、 为了解决开源组件Fresco在工程编译运行后提示找不到so文件并导致程序崩溃的问题。
2、 分享如何将开源组件Fresco的源码进行二次改写,实现与项目工程对接,并正常运行的方法。
案例描述:
在开发中,引入了第三方Facebook的开源组件Fresco后,发现无法与工程中的其它第三方库等带有(.so)文件的SDK库同时使用,并运行时提示
"nativeLibraryDirectories=[/data/app/com.lukouapp-1/lib/arm64, /vendor/lib64, /system/lib64]]] couldn't find "libxxxx.so"
找不到so文件,经过仔细排查发现是因为Fresco中包含了多个编译环境的so库文件,导致系统会找寻指定环境下的目录文件,从而无法找到工程中的其它第三方库等文件;
问题原因:64位机器默认去查找arm64-v8a目录下是否有合适的64位库,如果没有则会去libs下查找32位的库,而fresco的draw-pipeline太完善了考虑了64位的机器所以他的arm64-v8a下有so库,对应的系统就创建了lib64的文件,而不再去找32位的库。
本案例不重点讲述如何分析和找寻问题的,而是分享如何解决的方案。
案例分析:
所需要的环境:
Android Studio,任何正常的Android手机
调试方案:
断点调试,Log日志等观察分析
案例思路:
正常情况下,使用Android Studio时,我们引入Fresco的方法如下。
但是,当我们自己项目中有so文件库时,这种方式很容易造成崩溃的问题。
提示找不到so 包。
解决方法有两种:
方法一:
将项目中的so放入多个编译环境(armeabi-v7a, armeabi, arm64-v8a, x86, x86_64)目录下,这样会导致程序的so文件过多重复,程序过于庞大。此方法简单但过于笨拙,不建议使用。
方法二:
修改Fresco源码文件,通过GitHub下载源码,并导入Android Studio中,过程过于繁琐,在这不做详解。并且我们可以选择性的导入Fresco源码中的部分主要的Model工程,进行缩减阉割成轻量级的库。
原理分析:
本案例选择基础的Fresco库如下图。
从中删除不需要的so库文件环境,如下只保留工程所需要的armeabi环境。
编译并提成为新的轻量级Lib依赖库,名称为Fresco Lite,如下:
总结:
本案例提供问题方法的思路,并分享出精简版本的Fresco Lite库,适用于armeabi编译环境。
Fresco Lite库 GitHub地址:https://github.com/zyao89/Fresco-Lite.git