内容简介:导致这个问题出现的原因是因为我们在项目种使用了so库,或者项目中引用的三方sdk使用了so库。在引用so库时需要针对不同的cpu架构使用不同的.so文件。armeabi,armeabi-v7a,x86,arm64-v8a,大家通常会对这几个cpu架构进行适配。然而问题就出在现在Flutter在打包Apk时不能同引入arm32和arm64的这个问题在官方issues已经存在很久了暂时没有完美的解决方法,有新的方法我会第一时间更新。 后续我会持续更新一些Flutter开发时遇到的问题,以及一些好的文章(可能包含
导致这个问题出现的原因是因为我们在项目种使用了so库,或者项目中引用的三方sdk使用了so库。在引用so库时需要针对不同的cpu架构使用不同的.so文件。armeabi,armeabi-v7a,x86,arm64-v8a,大家通常会对这几个cpu架构进行适配。然而问题就出在现在Flutter在打包Apk时不能同引入arm32和arm64的 libflutter.so
。我门将打好包的Apk安装到arm64架构(默认打包会引入arm32)的手机上时就出现了couldn't find libflutter.so
这个异常。
如何解决
-
针对arm32和arm64分别打包(flutter 提供了命令来之分别对arm32和arm64分别打包)
-
flutter build apk --target-platform=android-arm32
-
flutter build apk --target-platform=android-arm64
我们用
flutter build apk --target-platform=android-arm64
打包apk,并在arm64cpu架构的手机安装运行,很好完美运行。但是当我们吧apk安装到32位时问题再次出现,原因就不再重复了。很显然到这里这个方式并不能解决这个问题,为了适配arm32和arm64我们需要分别打包,而国内大部分应用市场不能针对不同cpu架构上传不同的apk。 -
-
不对arm64做适配,打包时排除其他非arm32架构的so文件
这时候有些朋友可能会又疑问,问题不就是因为打包时没有引入arm64的libflutter的so文件导致在arm64架构手机上出现“兼容”问题的么。这里简单说一点关于引用so库的一些知识,了解的朋友大家直接跳过就可以。arm64cpu架构是可以像下兼容的,简单点就是arm64架构的cpu可以使用arm32的.so文件。出现问题真正原因是我们在引用so库时(引用的三方库中引用了so库),对arm64做了兼容。这样就会导致运行时系统误以为我们的应用对所有的so库做了arm64架构的兼容,但是在打包时libflutter并没有引入arm64的版本。这就导致系统去寻找arm64版本的libflutter发现找不到。系统误会了我们,我门只能通过gradle在打包时排除其他非arm32架构的so文件来解除这个误会。
好那如何排除其他非arm32架构的so文件。在app下的gradle文件加入如下代码
buildTypes { release { ndk{ //这里其实我觉可以直接是用"armeabi-v7a",但国内几个大哥之前使用的都是"armeabi" abiFilters "armeabi" } } debug { ndk { //这里要加上,否则debug包会出问题,后面三个为可选,x86建议加上不然部分模拟器回报错 abiFilters "armeabi", ,"armeabi-v7a","arm64-v8a", "x86" } } } 复制代码
最后
这个问题在官方issues已经存在很久了暂时没有完美的解决方法,有新的方法我会第一时间更新。 后续我会持续更新一些Flutter开发时遇到的问题,以及一些好的文章(可能包含生肉,本人英文能力有限尽量尝试炒熟)。希望能帮大家少走一些弯路。有些理解不到位也希望大家指正帮助进步,提前谢过大家。谢谢。
以上所述就是小编给大家介绍的《Flutter杂症(couldn't find "libflutter.so")》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- TypeScript 疑难杂症
- 话说 Kubernetes 网络疑难杂症
- Flutter杂症(InkWell,TextField)
- 疑难杂症篇之 ulimit
- TCP协议疑难杂症全景解析
- Autowired无法正常注入的疑难杂症
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。