HarmonyOS性能优化——并发能力使用

并发能力使用

应用中的并发优化是在响应用户操作时,确保主线程仅执行UI绘制任务,将非UI的耗时任务分配给其他线程或延迟处理。通过多线程异步技术,充分利用多核处理器的能力,提高应用程序的并发处理能力,减少用户等待时间,确保用户界面的响应流畅。

使用多线程能力

创建自定义组件后,在执行build函数前,将先调用aboutToAppear()生命周期回调函数。如果在此函数中执行耗时操作,将阻塞UI渲染并增加主线程负担。对于不需等待结果的高耗时任务,可以使用多线程处理,通过并发方式避免主线程阻塞,或者将耗时操作改为异步并发或延后处理,确保主线程优先处理组件绘制逻辑。ArkTS提供了TaskPool和Worker两种多线程并发方案,具体对比请参阅TaskPool和Worker的对比实践

使用异步能力

Promise和async/await提供异步并发能力,是标准的JS异步语法。异步代码会被挂起并在之后继续执行,同一时间只有一段代码执行,适用于单次I/O任务的场景开发,例如一次网络请求、一次文件读写等操作。无需另外启动线程执行。可以把耗时操作的执行从同步执行改为异步或者延后执行,比如使用setTimeOut执行耗时操作实现应用冷启动优化

多线程间通信

对象/方法在跨线程传递时均会涉及到其序列化和反序列化的过程。当对象本身较大且结构复杂时,序列化/反序列化的耗时就会增加,从而影响应用运行的整体性能。使用异步能力Sendable对象可以实现数据在多线程间的引用传递,具体使用场景请参阅Sendable使用场景案例分析

相关推荐
DemonAvenger14 小时前
Redis性能优化实战:从配置调优到代码实现的全面指南
数据库·redis·性能优化
流影ng15 小时前
【HarmonyOS】动画—转场动效
华为·harmonyos
程序边界16 小时前
MongoDB迁移到KES实战全纪录(下):性能优化与实践总结
数据库·mongodb·性能优化
武子康16 小时前
Java-160 MongoDB副本集部署实战 单机三实例/多机同法 10 分钟起集群 + 选举/读写/回滚全流程
java·数据库·sql·mongodb·性能优化·系统架构·nosql
cooldream200917 小时前
项目实战复盘:基于仓颉语言的鸿蒙智能导航助手(HarmonyNav)
华为·harmonyos·仓颉
爱笑的眼睛1117 小时前
HarmonyOS ScrollBar深度定制:超越系统默认的滚动体验
华为·harmonyos
爱笑的眼睛1117 小时前
HarmonyOS 文件管理Kit 的应用场景深度解析
华为·harmonyos
周倦岚17 小时前
【HarmonyOS】GC垃圾回收
harmonyos
HarmonyOS_SDK17 小时前
【FAQ】HarmonyOS SDK 闭源开放能力 — AppGallery Kit
harmonyos
SWUT胖虎18 小时前
ArkTS 自定义组件与 @Builder 区别总结
harmonyos·arkts·鸿蒙