闲鱼技术2022年度白皮书-Flutter主题-节日献礼:Flutter知识小报(下)

简介: 闲鱼技术2022年度白皮书-Flutter主题-节日献礼:Flutter知识小报

接上篇:https://developer.aliyun.com/article/1225938?spm=a2c6h.13148508.setting.28.595d4f0eudDbz0


六、 Flutter代码Trim机制的坑

 

我们都知道Flutter中的dart代码在编译过程中,会对没用调用到的代码进行裁剪。这样做的好处是尽可能减少产物的大小。以闲鱼场景为例关闭代码Trim,闲鱼的包大小会增加额外的8M。但是实际开发过程中的一个不起眼的操作,竟然会打入你可能意料之外的代码。

 

image.png


上述代码中dependencyCall所在代码是会在编译期间被trim掉的(如果没有其他任何引用的话)。但是如果代码改成了如下方案,情况就不同了。

 

image.png


由于在编译期间,编译器无法100%确认needSomething变量的值。所以就会将dependencyCall所在代码打入最终的包中。包大小就“意外”变大了。

 

一个非常小的改动,即便最后的值都是false,看起来是逻辑等价。但是“不经意间”却影响了最终打入的代码。

 

七、 Flutter为什么引入EngineGroup

 

众所周知,Flutter最早是面向APP级别进行设计的。但是实际应用过程中,更多的场景是将Flutter纳入现有的APP之中,这时Flutter多实例就是一个无法回避的问题。闲鱼团队之前的解决方案是FlutterBoost,目前也已经开源。本质上是多个页面复用一个Flutter Engine。

 

Flutter 2.0版本中,官方对Flutter多实例场景进行了优化。据官方数据,增加一个新的Flutter实例,只会增加约180K的内存占用。这无疑对多实例场景是一个重大利好。官方数据如下:

 


image.png

image.png


但是这个方案真的那么完美么?目前的EngineGroup方案也有他的一些不足:

 

每个Engine都有自己的Isolate,彼此之间数据独立无法复用。同时不同页面之间的数据通信的成本也大幅提升

每个Engine都有自己的桥通道。需要单独注册和管理

多Engine即便已经大幅优化,考虑到更多的Isolate和数据隔离。真实页面性能成本相比单Engine版本会更高

 

大家可以根据自己业务的实际情况选择使用

 

 

引用

【1】Flutter新一代图形渲染器Impeller

【2】https://github.com/flutter/flutter/wiki/Impeller

【3】https://docs.flutter.dev/development/tools/sdk/release-notes/release-notes-3.3.0

【4】FlutterBoost:https://github.com/alibaba/flutter_boost

 

相关文章
|
21天前
|
SQL 分布式计算 大数据
Flutter技术实践问题之Flutter应用过程中的基础建设如何解决
Flutter技术实践问题之Flutter应用过程中的基础建设如何解决
22 10
|
21天前
|
新零售 前端开发 小程序
Flutter技术实践问题之基于Flutter的Canvas的应用优势如何解决
Flutter技术实践问题之基于Flutter的Canvas的应用优势如何解决
20 2
|
21天前
|
Web App开发 新零售 前端开发
Flutter技术实践问题之阿里集团内Flutter体系化建设如何解决
Flutter技术实践问题之阿里集团内Flutter体系化建设如何解决
27 1
|
12天前
|
Kubernetes Cloud Native 搜索推荐
探索云原生技术:Kubernetes入门与实践打造个性化安卓应用:从零开始的Flutter之旅
【8月更文挑战第31天】云原生技术正改变着应用开发和部署的方式。本文将带你了解云原生的基石——Kubernetes,通过实际的代码示例,从安装到部署一个简单的应用,让你迅速掌握Kubernetes的核心概念和操作方法。无论你是初学者还是有一定经验的开发者,这篇文章都将成为你进入云原生世界的桥梁。
|
4月前
|
Dart 前端开发 测试技术
【Flutter前端技术开发专栏】Flutter开发中的代码质量与重构实践
【4月更文挑战第30天】随着Flutter在跨平台开发的普及,保证代码质量成为开发者关注的重点。优质代码能确保应用性能与稳定性,提高开发效率。关键策略包括遵循最佳实践,编写可读性强的代码,实施代码审查和自动化测试。重构实践在项目扩展时尤为重要,适时重构能优化结构,降低维护成本。开发者应重视代码质量和重构,以促进项目成功。
62 0
【Flutter前端技术开发专栏】Flutter开发中的代码质量与重构实践
|
3月前
|
开发框架 前端开发 测试技术
Flutter开发常见问题解答
Flutter开发常见问题解答
|
4月前
|
前端开发 C++ 容器
Flutter-完整开发实战详解(一、Dart-语言和-Flutter-基础)(1)
Flutter-完整开发实战详解(一、Dart-语言和-Flutter-基础)(1)
|
2天前
|
安全 Android开发 开发者
探索安卓开发的未来:Kotlin的崛起与Flutter的挑战
在移动开发的广阔天地中,安卓平台始终占据着举足轻重的地位。随着技术的不断进步和开发者需求的多样化,Kotlin和Flutter成为了改变游戏规则的新玩家。本文将深入探讨Kotlin如何以其现代化的特性赢得开发者的青睐,以及Flutter凭借跨平台的能力如何挑战传统的安卓开发模式。通过实际案例分析,我们将揭示这两种技术如何塑造未来的安卓应用开发。
17 6
|
19天前
|
开发框架 Android开发 iOS开发
Flutter相关痛点解决问题之淘特选择桌面端开发框架如何解决
Flutter相关痛点解决问题之淘特选择桌面端开发框架如何解决
|
1月前
|
移动开发 前端开发 JavaScript
"跨界大战!React Native、Weex、Flutter:三大混合开发王者正面交锋,揭秘谁才是你移动应用开发的终极利器?"
【8月更文挑战第12天】随着移动应用开发的需求日益增长,高效构建跨平台应用成为关键。React Native、Weex与Flutter作为主流混合开发框架各具特色。React Native依托Facebook的强大支持,以接近原生的性能和丰富的组件库著称;Weex由阿里巴巴开发,性能优越尤其在大数据处理上表现突出;Flutter则凭借Google的支持及独特的Dart语言和Skia渲染引擎,提供出色的定制能力和开发效率。选择时需考量项目特性、团队技能及生态系统的成熟度。希望本文对比能助你做出最佳决策。
76 1