从渲染流程、数据处理结构聊聊Flutter性能优化

news2024/12/26 21:55:37

不可否认 Flutter 是一个非常强大的移动应用开发框架,我们在技术架构选型时就是选用的 Flutter,特别是跨端能力属实很优秀,but 也逐渐发现在复杂的应用程序实现中,App 的性能会受到一些影响。

其实这个问题,我们内部也有发现,但是出于优先级的考虑,性能优化的需求一直没有排到迭代中,但是产品运营陆陆续续有接到用户反馈使用体验的问题,我们才把这个需求往前提,在需求评审和技术讨论后有一些实现路径结论,也借机在这里进行分享和交流。

Flutter 的渲染流程

在优化 Flutter 应用的性能之前,首先很有必要了解其渲染流程,理解这个流程对于性能优化至关重要。

Flutter 的渲染流程主要分为三个阶段:构建、布局和绘制。

  • 在构建阶段,Flutter会创建和配置widget;
  • 在布局阶段,Flutter会确定每个widget的位置和大小;
  • 在绘制阶段,Flutter会将widget绘制到屏幕上。

1、限制使用 widget 数量

在Flutter中,构建过多的widget会消耗大量的CPU资源,从而影响应用的性能。因此,我们应尽量减少构建的widget数量。例如,我们可以使用ListView.builder来构建列表,而不是使用ListView。因为ListView.builder只会构建屏幕上可见的widget,而ListView则会构建所有的widget。

2. 避免不必要的重绘

在Flutter中,如果一个widget的状态发生改变,那么这个widget以及其所有的子widget都会被重绘。因此,我们应该尽量避免不必要的重绘。例如,我们可以使用const来创建常量widget,这样这个widget就不会被重绘了。另外,我们也可以使用RepaintBoundary来隔离需要重绘的widget,这样就可以减少不必要的重绘。

Flutter 的数据处理结构

在处理大量数据时,使用正确的数据结构和算法是非常重要的。

1、巧用链表(LinkedList)

如果我们需要在列表中查找元素,那么使用哈希集(HashSet)会比使用列表(List)更高效。因为在哈希集中查找元素的时间复杂度是O(1),而在列表中查找元素的时间复杂度是O(n)。同样,如果我们需要频繁地在列表中添加或删除元素,那么使用链表(LinkedList)会比使用数组(Array)更高效。

2、使用懒加载

在处理大量数据时,我们可以使用懒加载来提高应用的性能。懒加载是一种只在需要时才加载数据的技术。例如,我们可以使用FutureBuilder或StreamBuilder来实现懒加载,这样就可以避免一次性加载所有的数据,从而减少内存的使用。

使用性能分析工具

Flutter其实有提供了一些性能分析工具,如 Flutter DevTools 和 DartDevTools。

如果我们多善用这些工具可以帮助我们找出性能瓶颈,从而进行针对性的优化。

例如,我们可以使用 Flutter DevTools 的 Timeline 视图来查看应用的帧率,以及每一帧的构建、布局和绘制时间。我们也可以使用 Dart DevTools 的 CPU 分析器来查看 CPU 的使用情况,以及每个函数的执行时间。

此外,我们在技术讨论的时候也发现,从图片缓存、JSON序列化、反序列化和拓展工具也可以实现。

在Flutter中,可以使用缓存来提高应用的性能。例如,我们可以使用图片缓存(ImageCache)来缓存图片,这样就可以避免每次都从网络上下载图片。另外,我们也可以使用Memoization技术来缓存函数的结果,这样就可以避免重复计算。

有些操作,如 JSON 序列化和反序列化,如果直接使用 Dart 的核心库进行操作,可能会影响应用的性能。因此,我们可以使用专门的库,如 json_serializable 和 built_value,来进行这些操作。

如果我们考虑从H5角度进行优化,我也非常建议使用小程序替代H5,让过往开发的小程序直接运行在 Flutter 开发的应用中,同样一个功能业务仅需一次小程序开发,即可实现在除了微信端的其它 App 中也运行起来,由于双线程技术会使得效果明显优于H5,白屏和卡顿的情况大大减少。原理其实很简单的,FinClip 提供了小程序 SDK给 Flutter 应用进行集成,这样一来 App 即拥有了一套可运行小程序业务代码的宿主环境。

总的来说,Flutter的性能优化是一个持续的过程,需要我们不断地学习和实践。优化的目标不仅是提高应用的运行速度,还包括提高应用的响应速度,减少应用的内存使用,以及提高应用的能效。希望我们深入的探索这些实用的技巧和最佳实践可以帮助在使用 Flutter 构建应用时,提高应用的性能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/702028.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringCloud入门实战(九)- SpringCloud Config配置中心

📝 学技术、更要掌握学习的方法,一起学习,让进步发生 👩🏻 作者:一只IT攻城狮 ,关注我,不迷路 。 💐学习建议:1、养成习惯,学习java的任何一个技术…

java List集合使用笔记

1、List集合的特点 有序集合、有序的序列,用户可以精准的控制元素插入的位置通过索引访问元素可以搜索元素与Set不同,List允许重复的元素存在 2、List集合特有的方法 add(索引,元素) remove(索引):返回的是被删除的索引 get(索引)&#xf…

Arduino uno 环境配置 for Mac

1、IDE 在官网下载 官网地址:https://www.arduino.cc/en/software 看到钱💰不要怕,只是问你捐不捐款,不收钱,你直接安装就行 (你也可以捐一点~) 安装之后 2、安装驱动 地址 &…

单片机-矩阵键盘密码锁

89C52RC芯片 1.矩阵按键输入正确密码&#xff0c;LCD1602右上角显示ok&#xff0c;错误显示Err。 涉及文件&#xff1a; 1.main.c (#include<regx52.h>) 2.lcd1602.c lcd1602.h 3.Delay.c Delay.h 4.MatrixKey.c MetrixKey.h 共7项 代码 main.c #…

此导入从不用作值,必须使用 “import type“ ,因为 “importsNotUsedAsValues“ 设置为 “error“。

前言 最近电脑更新了一次系统&#xff0c;重启后在 VsCode中打开项目 &#xff0c;发现原本正常的代码出现了一堆语法提示。网上搜了一下&#xff0c;没有找到关于此问题的回答&#xff0c;不知道我是不是第一个遇到的。在此记录一下这次的经历&#xff0c;如果有其他人遇到&a…

蓝桥杯专题-试题版含答案-【6174问题】【笨小熊】【鸡兔同笼】【小学生算数】

点击跳转专栏>Unity3D特效百例点击跳转专栏>案例项目实战源码点击跳转专栏>游戏脚本-辅助自动化点击跳转专栏>Android控件全解手册点击跳转专栏>Scratch编程案例点击跳转>软考全系列点击跳转>蓝桥系列 &#x1f449;关于作者 专注于Android/Unity和各种游…

突破APP广告收益天花板的多种数据优化方法

​APP开发者对于广告变现最关心的问题就是收益。事实上&#xff0c;广告收益与广告请求、曝光和点击等关键数据之间存在着密切的联系。这些数据的表现直接影响着广告的收益情况。 因此&#xff0c;开发者需要重视并优化这些关键链路数据。本文将介绍一些优化方法&#xff0c;帮…

zabbix 介绍及部署

目录 一、zabbix的基本概述 二、zabbix功能 &#xff08;一&#xff09;数据收集 &#xff08;二&#xff09;灵活的阈值定义 &#xff08;三&#xff09;高度可配置的告警 &#xff08;四&#xff09;实时图形 &#xff08;五&#xff09;网络监控功能 &#xff08;六…

牛客网专项练习——C语言错题集(10)

文章目录 两数相除后的数据类型if 语句表达式类似转义字符逗号表达式易错题指针概念异或刁钻题&#xff0c;多维数组地址自动变量 两数相除后的数据类型 C语言规定除法运算符( / )的运算结果的数据类型与被除数的数据类型保存一致&#xff0c;所以一个整数除以另一个整数的结果…

JPA 批量插入较大数据 解决性能慢问题

JPA 批量插入较大数据 解决性能慢问题 使用jpa saveAll接口的话需要了解原理&#xff1a; TransactionalOverridepublic <S extends T> List<S> saveAll(Iterable<S> entities) {Assert.notNull(entities, "Entities must not be null!");List<…

建设Web3需要Web2的人才?探索传统技能在Web3时代的作用

摘要&#xff1a;Web3作为下一代互联网技术的前沿&#xff0c;许多人关注着它的发展和应用。然而&#xff0c;建设Web3是否需要Web2的人才仍然是一个有争议的问题。 Web3作为下一代互联网技术&#xff0c;以去中心化、智能合约和用户自治等特点引起了广泛的关注。与此同时&…

基于STM32单片机的智能家居毕设

文章目录 一、硬件选型1、硬件清单2、硬件展示&#xff08;部分&#xff09; 二、效果展示1、整体效果展示2、显示屏&#xff08;触摸&#xff09;效果展示 三、功能分析1、系统总体结构框图2、主要包含的功能 四、怎么做&#xff1f;1、STM32单片机部分2、语音识别与播报部分3…

wamp环境解决局域网不能访问的问题!

安装好wamp后&#xff0c;想用手机通过局域访问电脑上wamp下的网页&#xff0c;结果出现如下提示403错误&#xff1a; 第一步&#xff1a;找到 conf 这个文件&#xff1a; 找到下图中红色方框中的onlineoffline tag - don’t remove&#xff0c;将原来的Require local替换为Re…

JMeter:如何开始简单的WEB压力测试?

目录 背景 如何开始简单的WEB压力测试 PutsReq网站截图 执行测试计划 背景 JMeter是一款广泛使用的性能测试工具&#xff0c;它可以模拟用户行为并生成负载&#xff0c;用于评估Web应用程序的性能和稳定性。 最近工作上被安排针对Web网站进行性能压测&#xff0c;以评估特…

chatgpt赋能python:关于Python除二取余法的优缺点分析

关于Python除二取余法的优缺点分析 Python是当前数据分析和科学计算最火热的语言之一&#xff0c;其中除二取余法是Python中很有趣的算法之一。它也是很常用的基础算法之一&#xff0c;特别是在图像处理和编码中&#xff0c;非常常用。除二取余法指的是一个数值除以二后的余数…

『手撕 Mybatis 源码』09 - MyBatis 插件

MyBatis插件 概述 问题&#xff1a;什么是Mybatis插件&#xff1f;有什么作用&#xff1f; Mybatis插件本质上来说就是一个拦截器&#xff0c;它体现了 JDK 动态代理和责任链设计模式的综合运用 Mybatis 中所允许拦截的方法如下 Executor 【SQL执行器】【update&#xff…

深信服行为感知系统远程命令执行

什么是男子汉?困难打不倒的人才是真正的男子汉&#xff01; 漏洞复现 构造payload访问漏洞url&#xff1a; /tool/log/c.php?strip_slashessystem&hostipconfig漏洞证明&#xff1a; 文笔生疏&#xff0c;措辞浅薄&#xff0c;望各位大佬不吝赐教&#xff0c;万分感谢…

linux服务器python2升级安装python3.7环境

文章目录 开始1. 首先&#xff0c;先检查自己的系统是否安装了python32. 如果你只是想安装python3.63. 安装python3.7的准备工作4. 安装python35. 添加软链接&#xff0c;让python3和pip3这两个命令指向刚刚安装的python3.76. 检验python3安装是否ok7. 更新默认 Python 版本8. …

Spring管理事务知识

目录 1.什么是事务 2.事务的特性ACID 3.Spring 管理事务的方式 4.Spring管理事务的体现&#xff1a;JDBCTemplate 5.声明式事务的属性有哪些 6.声明式事务属性---只读 7.声明式事务属性---超时 8.声明式事务属性---回滚策略 9.声明式事务属性---事务隔离级别 10.声明…

mac 安装 aab android包

一、配置bundletool环境 1、下载最新版的bundletool 版本号要最新的 bundletool-all-1.15.1.jarhttps://github.com/google/bundletool/releases/download/1.15.1/bundletool-all-1.15.1.jar Releases google/bundletool GitHub​​​​​​​​​​ 2、把bundletool放在…