本页面收集了一些关于评估和调试 Flutter 性能的常见问题。

  • 如何判断我的 Flutter 应用中哪些小部件在每个帧中重建了?
    • widgets/debug.dart 中将 debugProfileBuildsEnabled 设置为 true。
    • 或者,更改 widgets/framework.dart 中的 performRebuild 函数,使其忽略 debugProfileBuildsEnabled 并始终调用 Timeline.startSync(...)/finish
    • 如果您使用 IntelliJ,可以查看此数据的 GUI 视图。选择 Track widget rebuilds,您的 IDE 会显示哪些小部件正在重建。
  • 如何解决 Dart 昂贵的异步函数调用阻塞 UI 线程导致的应用动画卡顿问题?
  • 如何截取正在运行的应用屏幕并将其导出为 SKP 文件?
    • 运行 flutter screenshot --type=skia --observatory-uri=...
    • 注意一个已知的截图查看问题
    • 要分析和可视化 SKP 文件,请查看 Skia WASM 调试器
  • 如何从设备中检索着色器持久缓存?

    • 在 Android 上,您可以执行以下操作
      adb shell
      run-as <com.your_app_package_name>
      cp <your_folder> <some_public_folder, e.g., /sdcard> -r
      adb pull <some_public_folder/your_folder>
  • 如何在 Fuchsia 中执行跟踪?