Flutter性能优化的一些路径思考

news2024/12/28 19:51:49

不可否认 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/686198.html

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

相关文章

如何用Dialog DA1468X DK PRO测试其他板子的电流

2021.09.27 Jim 目录 工具准备... 1 PC上位机安装... 1 打开PC上位机... 1 消除DA1468X开发板本身底电流... 2 测试待测板子的功耗... 3 电压调节... 4 跳线帽... 6 工具准备 DA1468X DK PRO开发板一套,不需要装顶板的小板子,只需要母板&#…

「缤纷色彩的饼状图」:通过使用matplotlib库绘制饼状图,让读者期待在这个色彩缤纷的图表中探索数据的美丽。

嘿,大家好!今天我要带你们探索一个有趣的话题:使用matplotlib库绘制饼状图。虽然这听起来可能有些复杂,但我会用轻松幽默的语言给大家讲解!准备好了吗?让我们开始吧! 首先,我们需要导…

人工智能的奥秘:机器学习的各大门派

本篇文章是博主在人工智能等领域学习时,用于个人学习、研究或者欣赏使用,并基于博主对人工智能等领域的一些理解而记录的学习摘录和笔记,若有不当和侵权之处,指出后将会立即改正,还望谅解。 文章分类在学习摘录和笔记专…

2023网络安全 -- 正向连接与反向连接

一、正向连接,Linux服务器主动控制windows服务器 1、上传nc到windows服务器上运行 2、以管理员身份运行cmd 3、执行下面命令,监听任意来自8899端口的数据,等待服务器来连接 nc -e cmd -lvvp 8899 4、Linux服务器执行如下命令,i…

解决USB设备PC不识别问题思路(亲测方案)

前言: 因环境是集控封锁USB端口的,所以刚碰到用户出现此问题,一般都认为是策略封堵拒绝了,但经过后面测试及权限查看是没问题的,所以深究一看,完全是USB设备都没有被PC主机识别的问题。按常规我们一般碰到这…

渗透怎么学?渗透测试中超全的提权思路来了!

提权Webshell:尽量能够获取webshell,如果获取不到webshell可以在有文件上传的地方上传反弹shell脚本;或者利用漏洞(系统漏洞,服务器漏洞,第三方软件漏洞,数据库漏洞)来获取shell。 …

webpack3 打包vue项目导致app体积过大

问题说明:打包导致 js 很大,然后访问特别慢。 Q:如果你的 js 达到了好几M,(除了个别情况,比如的代码量真的超级大到不行,其实这个本身就不成立)。我最开始就是,打包了我…

CSDN个性化推荐系统-负反馈测试

文章目录 前言一、uc不感兴趣标签过滤测试1.uc不感兴趣标签获取(uc_unlike_tag_list)1.1个人中心界面1.2从标签中可以发现什么?1.3与研发确认点1.4设计开发1.5接口获取结果 2.推荐流文章标签获取(tag_list)2.1部分代码2.2基本标签校验2.3基本标签校验结果 3.推荐流u…

Linux——DNS域名解析服务

个人简介:云计算网络运维专业人员,了解运维知识,掌握TCP/IP协议,每天分享网络运维知识与技能。座右铭:海不辞水,故能成其大;山不辞石,故能成其高。 个人主页:小李会科技的…

【③MySQL 数据查询】:提高查询的效率

前言 ✨欢迎来到小K的MySQL专栏,本节将为大家带来MySQL数据查询的讲解(基本、分组、排序、聚合、分页、条件查询) 目录 前言一、基本查询二、条件查询三、聚合函数(统计函数)四、分组查询五、排序查询五、分页查询六、总结 一、基本查询 MySQ…

海格里斯HEGERLS仓储设备高端定制|四向穿梭车立体库仓储的重要设备换层提升机

随着科技的快速发展,仓储物流行业已慢慢的朝着无人化、自动化和智能化方向快速发展,用户的需求量也随之日益提升。自动化立体库早已成为很多企业智能仓的标配,可以实现仓库高层合理化、存取自动化、操作简便化。在立体仓库内,高位…

基于SQL Server数据库的安全性对策探究

数据库进阶课程论文 题 目:基于SQL Server数据库的安全性对策探究 作者姓名: 作者学号: 专业班级: 提交时间: 2023/6/4 目 录 1概述 1 2 SQL Server数据库的安全问题 1 2.1以使用者身份进入数据库 1 2&a…

区块链中怎么惩罚虚假信息的矿工,工作量证明POW,共识算法

目录 区块链中怎么惩罚虚假信息的矿工 工作量证明POW 什么是工作量证明? 现在出现了另一个问题:如果其他人偷看了小明的答案并且抢答了怎么办? 为什么区块可以安全广播? 共识算法 小结 区块链中怎么惩罚虚假信息的矿工 1…

二叉树|代码随想录2刷|11-34

222.完全二叉树的节点个数 链接:力扣 利用完全二叉树的性质,这个更容易想到,如何计算完全二叉树的节点数 | labuladong 的算法小抄 另一个二分的方法计算太偏了,既然时间复杂度都是O(logn*logn)&#xff0c…

Python读写xml(xml,lxml)Edge 浏览器插件 WebTab - 免费ChatGPT

Python读写xml(xml,lxml)Edge 浏览器插件 WebTab - 免费ChatGPT XML一、xml文件创建方法一:使用xml.dom.minidom1、文件、标签的创建 方法二:使用ElementTree 二、xml文件修改1、修改标签内容,属性2、增加子…

flask旅游数据可视化-计算机毕设 附源码81319

flask旅游数据可视化 摘要 信息化社会内需要与之针对性的信息获取途径,但是途径的扩展基本上为人们所努力的方向,由于站在的角度存在偏差,人们经常能够获得不同类型信息,这也是技术最为难以攻克的课题。针对旅游数据可视化等问题&…

阿里企业邮箱标准版、集团版和尊享版有什么区别?

阿里云企业邮箱版本分为免费版、标准版、集团版和尊享版,除了费用区别,功能方面有什么差异?如何选择企业邮箱版本?免费版0元适合初创型企业,标准版适合大、中、小型企业使用,涉及子公司之间邮箱通讯可以选择…

cesium多颗卫星绕着不同的轨道旋转示例

本示例的目的是介绍演示如何在vue+satellite项目中模拟多颗卫星的运行轨迹和覆盖状态。 直接复制下面的 vue+satellite源示例代码,操作2分钟即可运行实现效果 文章目录 示例效果配置方式示例代码相关API参考:示例效果 配置方式 1)查看基础设置:https://xiaozhuanlan.com…

knife4j 4.1.0(OpenAPI3)实现spring security或shiro权限注解内容显示

前两天写了个knife4j(swagger2)实现spring security或shiro权限注解内容显示,主要是使用knife4j 2.0.5来实现权限注解内容显示的扩展。 在Spring Boot 3 中只支持OpenAPI3规范,集成knife4j的stater:knife4j-openapi3-…

Deepin 20.08 linux 升级nvidia驱动 黑屏 报错nvrm api mismatch

驱动连接 https://us.download.nvidia.cn/XFree86/Linux-x86_64/535.54.03/NVIDIA-Linux-x86_64-535.54.03.run 安装过程 systemctl set-default multi-user.target reboot 重启到字符界面后 chmod x NVIDIA-Linux-x86_64-535.54.03.run sudo ./NVIDIA-Linux-x86_64-535.5…