美文网首页
Flutter 性能优化

Flutter 性能优化

作者: 旺仔_100 | 来源:发表于2023-06-12 20:28 被阅读0次
一、统计应用启动时间

使用如下命令行运行项目

$ flutter run --trace-startup --profile

它会在flutter的build下面生成start_up_info.json文件。里面包含四个时间(以微秒为单位):

  • 进入flutter引擎的时间
  • 展示应用第一帧时间
  • 初始化flutter框架时间
  • 完成flutter初始化时间
{
  "engineEnterTimestampMicros": 1529286666907,
  "timeToFrameworkInitMicros": 750731,
  "timeToFirstFrameRasterizedMicros": 839979,
  "timeToFirstFrameMicros": 832027,
  "timeAfterFrameworkInitMicros": 81296
}

二、跟踪Dart代码性能
Timeline.startSync('interesting function');
// iWonderHowLongThisTakes();
Timeline.finishSync();

使用profile模式运行,打开你应用程序的Observatory timeline页面,在“Recorded Streams”中选择‘Dart’复选框,并执行你想测量的功能。这个我试了试,似乎不太好用,没找到自己要的时间差。

debugDumpLayerTree()

三、调试应用程序层

flutter框架的每一层都提供了讲其当前状态或事件转储(dump)到控制台(使用debugPrint)功能。

  • Widget 树 debugDumpApp();
  • 渲染树 debugDumpRenderTree();
  • Layer树 debugDumpLayerTree();

但是由于这几个方法的输出都是很多的,而且控制台的格式都不太好看,所以很难用来做分析。

四、可视化调试

我们也可以通过设置debugPaintSizeEnabledtrue以可视方式调试布局问题。 这是来自rendering库的布尔值。它可以在任何时候启用,并在为true时影响绘制。 设置它的最简单方法是在void main()的顶部设置。

当它被启用时,所有的盒子都会得到一个明亮的深青色边框,padding(来自widget如Padding)显示为浅蓝色,子widget周围有一个深蓝色框, 对齐方式(来自widget如Center和Align)显示为黄色箭头. 空白(如没有任何子节点的Container)以灰色显示。

debugPaintBaselinesEnabled (opens new window)做了类似的事情,但对于具有基线的对象,文字基线以绿色显示,表意(ideographic)基线以橙色显示。

debugPaintPointersEnabled (opens new window)标志打开一个特殊模式,任何正在点击的对象都会以深青色突出显示。 这可以帮助我们确定某个对象是否以某种不正确的方式进行hit测试(Flutter检测点击的位置是否有能响应用户操作的widget),例如,如果它实际上超出了其父项的范围,首先不会考虑通过hit测试。

如果我们尝试调试合成图层,例如以确定是否以及在何处添加RepaintBoundary widget,则可以使用debugPaintLayerBordersEnabled (opens new window)标志, 该标志用橙色或轮廓线标出每个层的边界,或者使用debugRepaintRainbowEnabled (opens new window)标志, 只要他们重绘时,这会使该层被一组旋转色所覆盖。

所有这些标志只能在调试模式下工作。通常,Flutter框架中以“debug...” 开头的任何内容都只能在调试模式下工作

五、DevTools

运行debug版本,在Android studio下面有个run控制台,上面的dart图标点击一下就可以进入可视化调试界面。


image.png

相关文章

  • Flutter优化相关

    Flutter之禅 内存优化篇Flutter ImageCacheFlutter 性能优化 Tips

  • Flutter相关优化

    性能优化 1、内存优化使用flutter performance等工具查看内存和帧率使用DevTools来gc查看...

  • flutter 性能优化

    中文文档:https://flutter.cn/docs/testing/best-practices英文文档:h...

  • Flutter性能优化

    1.圆角对性能的影响尽量避免用Clipxxx组件,建议用BoxDecoration的image属性实现,如果用Cl...

  • Flutter之禅 内存优化篇

    Flutter之禅 内存优化篇 前言 性能稳定性是App的生命,Flutter带了很多创新与机遇,然而团队在享受F...

  • Flutter 性能优化3

    适用于多次数据变化 既然有了FutureBuilder 一次性的数据变化更新视图,那就有多次,那就来看看Strea...

  • Flutter 性能优化1

    适用于无状态的组件 在Flutter 布局中,进程因为布局嵌套过多而提取成方法的形式实现,这样确实方便查看,但是当...

  • Flutter 性能优化2

    仅适用于一次数据更新,例如:在initState加载异步数据 flutter在布局中,我们除了无状态小部件还有有状...

  • Flutter的性能优化

    前言 本文是就Flutter的数据更新形式来操作,然后通过以观测观测台的状态数据报告,来完成对代码执行效率的监控,...

  • Flutter 性能优化细节

    1.重建最小化原则 在调用 setState() 方法重建组件时,一定要最小化重建组件,没有变化的组件不要重建 点...

网友评论

      本文标题:Flutter 性能优化

      本文链接:https://www.haomeiwen.com/subject/ovjnurtx.html