Flutter 中 async 操作符的隐藏成本

参考原文:The hidden cost of async operations in Flutter/Dart | by Rei | ITNEXT

本文主要讲解 void 和 async 一起使用时,容易忽略掉的两种情况而导致的性能问题。

冗余 async

我们会不自觉将如下两种写法等价

不就是多个 async 么,没啥大不了的。

那么事实真的是"等价"的么?

这里用 Dart 官方benchmark_harness基准测试工具测试一把两个方法耗时情况。

benchmark_harness可以通过覆盖 exercise 方法来上报 run()一次的平均时间(单位是微秒),默认使用 10 次迭代,我们修改成 100K 次。

运行结果:

表明方法 b 冗余的 async 关键字导致比方法 a 慢(143 倍,当然每个机器不一样这个倍速不同)很多,但是确实导致应用程序运行变慢很多。

上述情况容易发生的原因,跟 void 返回有关,不管加不加 async,编译器都不会报错,大不了就是个警告,无视之~~~ 。如果返回值是 int, 这种可能就会直接报错,开发者自然会去修改。

但有返回值的情况下,需注意如下冗余 async 情况, 比如 f() 的时间也会高于 e,不必要的 async 还是不要冗余加

await vs unawaited

还是返回是 void 的情况,这里我们加上上述情况中心心念念的 Future 来做另外一个实验。

一样,啥都不干,规规矩矩加上 Future。然后来看不同调用差异,方法 c 用 await 方法 d 用 unawaited。

运行结果:

结果显而易见,unawaited 更快。

unawaited 作用是启动一个 Future,但是不等它完成就继续。

比如日志记录,通常情况下知道日志记录会在某个时刻完成,而不需要等待它完成就可以了。这个时候可以用 unwaited。

简单来说,Future 有非错误结果,但是不关心它的这个结果,就可以用 unwaited。 如果这个过程中有错误结果,可能捕捉不到了。

那么如何解决平时遇到上述情况呢?

解决办法

通过 linter 规则来阻止此类问题。

下面是 linter 的一些并发规则

说到这里还是有点心虚,毕竟规则也可以无视,

  1. 可增加到代码提交规范
  2. 可增加到 CI/CD 流程中

源码传送门

相关推荐
雨白1 小时前
重识 Java IO、NIO 与 OkIO
android·java
啦啦9117142 小时前
Niagara Launcher 全新Android桌面启动器!给手机换个门面!
android·智能手机
游戏开发爱好者82 小时前
iOS 上架要求全解析,App Store 审核标准、开发者准备事项与开心上架(Appuploader)跨平台免 Mac 实战指南
android·macos·ios·小程序·uni-app·iphone·webview
xrkhy2 小时前
canal1.1.8+mysql8.0+jdk17+redis的使用
android·redis·adb
00后程序员张2 小时前
混淆 iOS 类名与变量名的实战指南,多工具组合把混淆做成工程能力(混淆 iOS 类名变量名/IPA 成品混淆Ipa/Guard CLI 实操)
android·ios·小程序·https·uni-app·iphone·webview
介一安全3 小时前
【Frida Android】实战篇1:环境准备
android·网络安全·逆向·frida
许愿OvO4 小时前
MySQL触发器
android·mysql·adb
循环不息优化不止4 小时前
Jetpack Compose 从重组到副作用的全方位解析
android
sunly_4 小时前
Flutter:视频预览功能
javascript·flutter·音视频
2501_916007476 小时前
iOS文件管理工具深度剖析,从系统沙盒到跨平台文件操作的多工具协同实践
android·macos·ios·小程序·uni-app·cocoa·iphone