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

不可否认 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.hqwc.cn/news/4421.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

九、会话控制——cookie、session、token

文章目录 前言一、cookie1.1 cookie 是什么1.2 cookie 的特点1.3 cookie 的运行流程1.4 express 框架中设置cookie1.5 express 框架中删除cookie1.6 express 框架中获取cookie 二、session2.1 session 是什么2.2 session 的作用2.3 session 的运行流程2.4 session 和 cookie 的…

Linux进程信号【信号产生】

✨个人主页: 北 海 🎉所属专栏: Linux学习之旅 🎃操作环境: CentOS 7.6 阿里云远程服务器 文章目录 🌇前言🏙️正文1、进程信号基本概念1.1、什么是信号?1.2、信号的作用1.3、信号的…

Spring Boot 中的 @Cacheable 注解

Spring Boot 中的 Cacheable 注解 在 Spring Boot 中,缓存是一个非常重要的话题。当我们需要频繁读取一些数据时,为了提高性能,可以将这些数据缓存起来,避免每次都从数据库中读取。为了实现缓存,Spring Boot 提供了一…

线性代数高级--二次型--特征值与特征向量--特征值分解--多元函数的泰勒展开

目录 二次型 概念 示例 性质和特点 特征值与特征向量 概念 示例 注意 性质和特点 特征值分解 注意 多元函数的泰勒展开 回顾一元函数泰勒展开 多元函数的泰勒展开 二次型 概念 二次型是一个关于向量的二次多项式,通常用矩阵表示。 考虑一个n维向量…

有哪些免费好用的Python IDE(集成开发环境)?

工欲善其事,必先利其器。Python的学习过程少不了集成开发编辑环境(IDE)。这些Python IDE会提供插件、工具等帮助开发者加快使用Python开发的速度,提高效率。这里收集了一些对开发者非常有帮助的Python IDE(来自hittp://doc.okbase.net/havoc/archive/242…

Gitlab 双重认证和访问令牌的使用

目录 引言 1、双重认证让项目只能使用访问令牌克隆 2、创建项目访问令牌 3、创建群组访问令牌 引言 双重认证可以提高用户账户的安全性,防止密码泄露,他人随意登录。 访问令牌就相当于项目或群组的访问密码,有了它就可以克隆项目。同时访…

「STC8A8K64D4开发板」第2-6讲:串口通信

第2-6讲:串口通信 学习目的掌握USB转串口电路的原理和设计。学习STC8A8K64D4的串口通信,包括串口初始化、波特率计算、串口发送和接收。编写串口收发程序,尤其是串口接收的软件缓存处理。编写串口发送命令控制LED指示灯亮灭的程序。 硬件电路…

pikache靶场通关——SSRF攻击

文章目录 前言环境第一关、SSRF(curl)Step.1、http协议链接本地文件Step.2、file协议读取C盘下的配置文件Step.3、dict协议扫描内网其他主机的端口开放情况Step.4、使用burp扫描内网其他主机的端口开放情况Step.5、后端源码分析 第二关、SSRF(file_get_c…

SpringBoot小结

目录 基本介绍 SpringBoot快速入门 开发步骤 1.创建新模块 2 .创建 Controller 3 启动服务器 可能会出现的问题:端口被占用 解决方法: 1. 暴力:找到占用的端口号,并且找到对应的进程,杀死该进程,释放…

计算机网络-数据链路层上篇

目录 一、数据链路层概述 二、封装成帧 三、差错检测 (一)奇偶校验 (二)循环冗余校验CRC 四、可靠传输 (一)停止-等待协议SW (二)后退N帧协议GBN (三&#xff…

AutoSAR系列讲解(入门篇)4.6-BSW的Watchdog功能

一、架构与术语解释 前面都挺难的吧?实践出真知,后面实践篇的时候,大家应该就能明白了。这一节就来讲个简单的功能------看门狗。看门狗想必大家应该都再熟悉不过了吧,主要就下面三层结构,简单明了,这节确实…

mac 文件批量重命名001开始

mac 文件批量重命名001开始,怎么操作?我们平时在整理办公文件的时候,经常需要对文件的名称进行修改,将文件修改为数字形式的名称,例如001、002、003、004......这样的形式,尤其是某项工作涉及非常多文件的时…