7.1 Flutter 性能模型

了解 Flutter 的帧渲染流程和 Jank 产生原因,是性能优化的理论基础。


一、Frame 渲染流程

Flutter 以每秒 60 帧(或 120 帧)的节奏渲染界面,每帧有约 16ms (60fps)或 8ms(120fps)的预算。

复制代码
每帧渲染流程(Pipeline)

① Build 阶段(Dart/UI Thread)
   Widget.build() 被调用
   → 生成/更新 Element 树
   → 创建/更新 RenderObject

② Layout 阶段(Dart/UI Thread)
   RenderObject.performLayout()
   → 从根节点递归计算每个 Widget 的尺寸和位置
   → 父节点向子节点传递约束(Constraints)

③ Paint 阶段(Dart/UI Thread)
   RenderObject.paint()
   → 将绘制命令记录到 PictureRecorder
   → 生成 Layer Tree

④ Composite 阶段(GPU Thread / Raster Thread)
   Layer Tree → Skia/Impeller
   → 生成 GPU 指令
   → 提交给 GPU 渲染

⑤ Display 阶段
   GPU 输出像素 → 显示到屏幕

线程模型:

线程 职责
UI Thread(Dart) 执行 Dart 代码,处理 Build/Layout/Paint
Raster Thread(GPU) 栅格化,将 Layer Tree 转为 GPU 指令
IO Thread 图片解码、文件读写
Platform Thread 处理平台 Channel 调用

二、Jank 与帧丢失原因分析

Jank 是指帧渲染时间超出预算(16ms),导致帧被丢弃,用户感知到卡顿。

2.1 UI Thread 卡顿(Build/Layout/Paint 耗时)

原因 表现 解决方案
Widget 频繁无效重建 build() 调用过多 const 构造函数,精细化 setState
复杂布局嵌套 Layout 阶段耗时 减少嵌套,使用 CustomMultiChildLayout
主线程同步 I/O 阻塞 UI Thread 使用 async/await 异步处理
复杂计算在主线程 16ms 内无法完成 使用 Isolate 或 compute

2.2 Raster Thread 卡顿(GPU 渲染耗时)

原因 表现 解决方案
Shader 首次编译(Jank) 首次动画卡顿 Impeller / SkSL 预热
过度绘制(Overdraw) 大量透明层叠加 RepaintBoundary,减少透明度
图片过大未压缩 内存占用高,解码慢 指定 cacheWidth/cacheHeight
大量图层合成 Composite 费时 控制 Layer 数量

2.3 帧丢失可视化

复制代码
正常:|帧1|帧2|帧3|帧4|帧5|...    每帧 ≤ 16ms
丢帧:|帧1|     帧2     |帧3|...   帧2 耗时 32ms,丢失1帧

三、性能指标

指标 说明 目标
FPS 每秒帧数 60 fps(流畅),120 fps(高刷)
帧耗时 单帧渲染时长 < 16ms(60fps)
Jank 率 丢帧比例 < 1%
启动时间 冷启动到首帧 < 1s(目标)
内存占用 RSS(实际物理内存) 根据设备档位分级

小结

概念 要点
帧预算 60fps = 16ms/帧,超时丢帧引发 Jank
Build → Layout → Paint → Composite 四步渲染流水线
UI Thread 执行 Dart 代码,最容易成为瓶颈
Raster Thread GPU 渲染,Shader 编译卡顿常见原因
Jank 原因 过度重建、同步耗时操作、过度绘制

👉 下一节:7.2 性能调试工具

相关推荐
zeqinjie9 小时前
Flutter 折叠屏 iPad / 宽屏适配实践
android·前端·flutter
程序员老刘12 小时前
本地跑Gemma 4 12B写Flutter:是惊喜还是崩溃
flutter·ai编程
暗冰ཏོ12 小时前
Flutter 从入门到项目实战:Dart 基础、跨平台开发、App 架构与上线发布完整指南
flutter·架构·app·安卓·应用开发
brycegao15 小时前
Flutter Dart JSON 解析必坑!金额精度丢失为什么必须在网络层处理?附工业级解决方案
flutter·dart
tangweiguo0305198715 小时前
Flutter GetIt 完全指南:告别 BuildContext 依赖的终极方案
flutter
韩曙亮15 小时前
【Flutter】Flutter 中的 Android / iOS 特殊配置 ① ( 网络权限配置 | HTTP 明文传输配置 | 应用名称配置 )
android·网络·flutter·http·ios·网络权限
tangweiguo0305198715 小时前
Flutter中的StreamController完全指南
flutter
hxy060117 小时前
Flutter showModalBottomSheet等弹窗宽度问题
前端·flutter
张3蜂18 小时前
Flutter Hello World!实践
flutter