Flutter瘦身大作战 压缩减小flutter的方法介绍
背景闲鱼技术团队于2018年上半年率先引入了Flutter技术实现客户端开发,到目前为止成功改造并上线了复杂的商品详情和发布业务。随着改造业务的增多,安装包体积急剧上增。安装包体积决定了用户等待下载的时间和可能会耗费的流量,如何控制安装包体积,减小flutter产物的大小成为当务之急。本文从闲鱼客户端项目实践角度给出了一些通用的包大小检测以及优化方案,希望为准备转型Flutter的团队提供参考。 闲鱼客户端采用的Flutter和Native混合开发的模式,下面我们以ios端为例分析项目中flutter产物的大小(ipa包瘦身需求更为急切)。 ios工程对Flutter有如下依赖:
第一次引入flutter版本改造详情页后,ipa包大小增加近20M,其中包括flutter引擎代码+被改造业务代码,继续发布页flutter改造后,ipa增加4M+。进一步分析解压ipa文件后发现Flutter.framework稳定保持在20M+的大小, 增加新的flutter业务——发布页之后,App.framework增幅近10M! Flutter.framework是Flutter库和引擎的代码,我们能做的优化空间有限,先把目标放在dart业务相关的文件App.framework上。 Flutter产物大小分析执行如下命令编译出一个release模式下的App.framework,并使用 flutter build aot --release --extra-gen-snapshot-options=--print-snapshot-sizes 结果如下: Building AOT snapshot in release mode (android-arm-release)... VMIsolate(CodeSize): 4660 Isolate(CodeSize): 2585632 ReadOnlyData(CodeSize): 2693576 Instructions(CodeSize): 8064816 Total(CodeSize): 13348684 Built to build/aot/. Instructions:代表AOT编译后生成的二进制代码大小 ReadOnlyData:代表生成二进制代码的元数据(例如PcDescriptor, StackMap,CodeSourceMap等)和字符串大小 VMIsolate/Isolate:代表剩下的对象的大小总和(例如代码中定义的常量和虚拟机特定元数据) 具体到业务层,想要分析各个业务模块所占用的大小该怎么办呢?
image
image 举个例子,上面的分析显示 PItemInfoInternal.fromJson(Map<dynamic, dynamic> map) { id = map['id'] as String; attributes = map['attributes'] as String; title = map['title'] as String; ...... } 由此我们可以推断这种类型转换的操作会导致编译生成一些体积很大的代码。 优化措施
//编译release包并打印sizeflutter build aot --release --extra-gen-snapshot-options=--print-snapshot-sizes//--dwarf_stack_traces, -->减少6.2%大小flutter build aot --release --extra-gen-snapshot-options="--dwarf_stack_traces,--print-snapshot-sizes"//--obsfuscation, -->减少2.5%大小flutter build aot --release --extra-gen-snapshot-options="--dwarf_stack_traces,--print-snapshot-sizes,--obfuscate"//总大小减少8.7%
RunCommand xcrun dsymutil -o "${build_dir}/aot/App.dSYM" "${app_framework}/App"RunCommand xcrun strip -x -S "${derived_dir}/App.framework/App"
image 总结引入Flutter带来的安装包体积问题会给很多技术团队带来困扰。通过以上措施,Flutter产物App.framework的大小减少30%+,闲鱼技术团队后续也会考虑采取下载并懒加载等方式减少资源占用的体积;继续代码生成中的各种对比,排查避免较大产物的写法,同时也会和Google一起进一步寻找优化空间。 闲鱼期待你的加入欢迎加入闲鱼,一起探索Flutter更多可能。 参考
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |