1024 节日抽奖|解锁新专栏【知识小报】

本期知识小报的主要内容包括:

  • Flutter NullSafty有用么?

  • Flutter 代码Trim机制的坑?

  • Flutter为什么引入EngineGroup?

  • Android折叠屏咋适配?

  • 抽奖有礼!

Flutter NullSafty有用么?

Flutter从2.0版本开始引入Dart语言的NullSafty 特性,并且在Flutter2.2版本中默认开启Dart3.0版本中已经明确不再支持非NullSafty代码。引入NullSafty特性能带来的明显收益:

  1. 1. 在编译期对变量的空安全做强保护。并且IDE会在代码静态扫描的过程中,直接给出空安全相关的提示。这无疑大幅提升了编码效率和代码质量

696bab378911efb72eed43dff2a2d4cd.png eef6a805e137a75b694e4fd4398510dc.png
  1. 2. Dart编译器能针对支持NullSafty的代码进行更多优化以生成体积更小,性能更佳的程序

  2. 3. 代码表达更加精简

    非NullSafty,

504f8a4abd6984cf3cf58f93cb42db20.png

    NullSafty

22a754c67e7f788864ffca01f1d0d579.png ok 如果你想将自己的现有的代码迁移到NullSafty 。 可以有多种方案可用:
  1. 1. 将Flutter项目中的dart Sdk版本改成>=2.12。整个工程即可开启NullSafty。

  2. 2. 如果整体开启工作量太大,可以改成单个文件开启。只需要在dart文件的最开始(一定要最顶上写)添加如下注释即可:

fc5f7557001d918580a2a3425c617e8a.png

Flutter 代码Trim机制的坑

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

67159212d268c5a1c79b7d59496a4a78.png

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

29e2cafe8d2349f05b82b7cdc3137b03.png

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

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

Flutter为什么引入EngineGroup

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

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

一个engine两个engine
5f753d46486ae63f77f2638ccf163987.png52c5e39b358fead57056200ef492ddc4.png

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

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

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

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

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

Android折叠屏怎么适配?

从2018年Google发布Android 9.0首次支持折叠屏到现在适配方案主要经历了三个阶段 

1. Android官方折叠屏适配指南。主要从以应用连续性、屏幕尺寸兼容性和多窗口模式 几个方面进行适配

944ae88f4d1398512fe1334324e409fa.gif

2. 各个厂商陆续推出自己的折叠屏手机以及各自的补充适配方案,需要开发者按照厂商机型分别适配,例如华为的easygo方案,通过json 配置文件支持平行视界模式。

3. Android 12L新增了Activity embedding,为所有类型的可折叠设备提供统一 API,避免各设备单独适配。

让开发者以最小的开发成本、更加有效的实现方式来 为大屏幕构建应用。

  1. 1. 配置依赖项,将WindowManager库依赖项添加到应用的build.gradle文件中

df83dc785068afc38ca964a6534e04bd.png

  1. 2. 配置分屏规则

    可以通过XML静态配置

a134cbb4117899a47ff12da514628960.png

    也可以在运行时动态配置

8a47201978aca9db796270bacfa9f44a.png

  1. 3. 设置配置初始化

aa62482bba3705b0b6063bd4621ee947.png

  1. 4. AndroidManifest中配置启动执行上一步的初始化类ExampleWindowInitializer

c975ec1be9cd3ab761661c4054075ccc.png

引用:

Lightweight Flutter Engines:https://github.com/flutter/flutter/issues/72009

Android官方折叠屏适配指南:https://developer.android.google.cn/guide/topics/ui/foldables?hl=zh-cn

Sound null safety:https://dart.dev/null-safety

FlutterBoost:https://github.com/alibaba/flutter_boost

抽奖有礼

礼物 1

1024是属于每位开发者同学的节日~

该怎么回馈闲鱼技术的粉丝朋友们呢?

格子衬衫文化衫?闲鱼ip手办?

基于对大家过往关注的观察洞察分析,共同成长才是我们的共同目标。

公众号小姐姐用心为大家首发新专栏:【知识小报】,希望新老朋友喜欢这个新的尝试。

礼物 2

此外,我们还准备了若干份神秘礼物!

  1. 转发本文到朋友圈,与更多开发者伙伴分享快乐

  2. 10月26日前将截图私信给后台

  3. 就有机会获得神秘小礼物🎁,随机抽取5位同学。

🎉闲鱼技术祝大家1024节日快乐🎉

  • 1
    点赞
  • 0
    收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值