• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# 长时任务并发场景简介
2<!--Kit: ArkTS-->
3<!--Subsystem: CommonLibrary-->
4<!--Owner: @lijiamin2025-->
5<!--Designer: @weng-changcheng-->
6<!--Tester: @kirl75; @zsw_zhushiwei-->
7<!--Adviser: @ge-yafang-->
8
9在应用业务实现过程中,需要较长时间不定时运行的任务称为长时任务。如果在UI主线程中执行这些长时任务,会阻塞UI业务,导致卡顿和丢帧等问题,影响用户体验。因此,通常需要将这些独立的长时任务放到单独的子线程中执行。
10
11典型的长时任务场景如下所示:
12
13
14| 常见业务场景 | 具体业务描述 |
15| -------- | -------- |
16| 定期采集传感器数据 | 周期性采集一些传感器信息(例如位置信息、速度传感器等),应用需要长时间不间断的运行。 |
17| 监听Socket端口信息 | 长时间监听Socket数据,不定时需要响应处理。 |
18
19上述业务场景均为独立的长时任务,任务执行周期长,与外部交互简单。分发到后台线程后,这些任务需要不定期响应以获取结果。使用TaskPool可以简化开发工作量,避免管理复杂的生命周期,避免线程泛滥。开发者只需要将上述独立的长时任务放入TaskPool队列,再等待结果即可。
20