鸿蒙原生应用开发-ArkTS语言基础类库多线程TaskPool和Worker的对比(一)

鸿蒙时代
发布于 2024-3-25 14:05
浏览
0收藏

TaskPool(任务池)和Worker的作用是为应用程序提供一个多线程的运行环境,用于处理耗时的计算任务或其他密集型任务。可以有效地避免这些任务阻塞主线程,从而最大化系统的利用率,降低整体资源消耗,并提高系统的整体性能。
本文将从实现特点和适用场景两个方面来进行TaskPool与Worker的比较,同时提供了各自运作机制和注意事项的相关说明。
一、实现特点对比
鸿蒙原生应用开发-ArkTS语言基础类库多线程TaskPool和Worker的对比(一)-鸿蒙开发者社区
二、适用场景对比
TaskPool偏向独立任务维度,该任务在线程中执行,无需关注线程的生命周期,超长任务(大于3分钟)会被系统自动回收;而Worker偏向线程的维度,支持长时间占据线程执行,需要主动管理线程生命周期。
常见的一些开发场景及适用具体说明如下:
有关联的一系列同步任务。例如在一些需要创建、使用句柄的场景中,句柄创建每次都是不同的,该句柄需永久保存,保证使用该句柄进行操作,需要使用Worker。
需要频繁取消的任务。例如图库大图浏览场景,为提升体验,会同时缓存当前图片左右侧各2张图片,往一侧滑动跳到下一张图片时,要取消另一侧的一个缓存任务,需要使用TaskPool。
大量或者调度点较分散的任务。例如大型应用的多个模块包含多个耗时任务,不方便使用8个Worker去做负载管理,推荐采用TaskPool。

本文参考引用HarmonyOS官方开发文档,基于API9。

分类
鸿蒙原生应用开发-ArkTS语言基础类库多线程.docx 20.8K 23次下载
收藏
回复
举报
回复
    相关推荐