# 【鸿蒙开发】多线程之Worker的使用

【鸿蒙开发】多线程之Worker的使用


文章目录

  • 【鸿蒙开发】多线程之Worker的使用
  • 前言
  • 一、Worker的介绍
  • 二、注意事项
  • 三、Worker使用示例
    • 1.新建一个Worker
    • 2.主线程使用Worker
    • 3.子线程Worker的使用
  • 四、效果展示


前言

本文主要介绍了多线程的方法之一,使用Worker开启多线程,介绍了如何使用Worker。之前发布过TaskPool的使用,大家可以点击链接查看。
# 【鸿蒙开发】多线程之TaskPool的使用


一、Worker的介绍

Worker 是用于多线程并行任务处理的,能利用多核优势提效。在程序里,主线程管界面交互、任务调度,Worker 线程专注耗时计算或异步操作,像处理大数据、渲染复杂图形、密集网络请求时,让主线程保持灵敏,快速响应操作。Worker最多支持64个多线程,TaskPool没有这个限制。workder是通过onMessage和postMessage发消息实现主线程和子线程的通信的,TaskPool是通过参数的方式进行通信。

二、注意事项

1、及时关闭 Worker:开发者要清楚,Worker 完成任务后,得手动关闭,如果不关闭,资源会一直被占用,导致系统性能下降,甚至可能内存泄漏。
2、避免主线程卡顿:Worker 在多线程编程里很重要,主要负责处理耗时任务,像大数据处理、频繁网络请求等。它能帮主线程分担压力,让主线程专注用户交互与任务调度,快速响应操作
3、谨慎共享资源:虽然 Worker 线程和主线程能共享部分资源,但开发时不能过度依赖。多个 Worker 线程同时读写同一共享资源,容易混乱,导致数据出错、不一致,尽量给 Worker 配独立资源。

三、Worker使用示例

1.新建一个Worker

在这里插入图片描述

2.主线程使用Worker

Worker是通过onMessage和postMessage进行主线程和子线程通信的

  //worker的使用
  getWorker() {
    const work1 = new worker.ThreadWorker("entry/ets/workers/Worker.ets")
    work1.postMessage(123) //主线程给子线程发消息
    //主线程接收消息
    work1.onmessage = (event) => {
      // event.data-可以拿到子线程发送的消息
      AlertDialog.show({ message: '收到子线程发的消息' + JSON.stringify(event)})
      work1.terminate() //worker需要自毁或者再Workers那执行workerPort.close()
    }
  }

主线程完整代码:

import { worker } from '@kit.ArkTS';

@Entry
@Component
struct Index {

  aboutToAppear(): void {
    this.getWorker()
  }

  //worker的使用
  getWorker() {
    const work1 = new worker.ThreadWorker("entry/ets/workers/Worker.ets")
    work1.postMessage(123) //主线程给子线程发消息
    //主线程接收消息
    work1.onmessage = (event) => {
      // event.data-可以拿到子线程发送的消息
      AlertDialog.show({ message: '收到子线程发的消息' + JSON.stringify(event) })
      work1.terminate() //worker需要自毁或者再Workers那执行workerPort.close()
    }
  }

  build() {
    RelativeContainer() {
    }
    .height('100%')
    .width('100%')
  }
}

注意事项:本次演示代码路径
在这里插入图片描述
如果代码测试请求数据,注意在modules.json5中开启网络权限
在这里插入图片描述

3.子线程Worker的使用

子线程创建时会生成代码,我们在workerPort.onmessage中处理和主线程的通信即可。

workerPort.onmessage = async (e: MessageEvents) => {
  // e.data  可以拿到主线程传的消息
  console.log(' 接收到主线程发来的消息-----> ', e.data)
  const req = http.createHttp()
  const res = await req.request('https://xxx/home/banner')
  //子线程给主线程发消息--将请求结果返回
  workerPort.postMessage(JSON.stringify(res))
  // 如果主线程没有关闭worker,主线程可以让worker自焚
  // workerPort.close() //自毁
}

子线程完整代码:

import { ErrorEvent, MessageEvents, ThreadWorkerGlobalScope, worker } from '@kit.ArkTS';
import { http } from '@kit.NetworkKit';

const workerPort: ThreadWorkerGlobalScope = worker.workerPort;

/**
 * Defines the event handler to be called when the worker thread receives a message sent by the host thread.
 * The event handler is executed in the worker thread.
 *
 * @param e message data
 */
workerPort.onmessage = async (e: MessageEvents) => {
  // e.data  可以拿到主线程传的消息
  console.log(' 接收到主线程发来的消息-----> ', e.data)
  // AlertDialog.show({ message: '接收到主线程发来的消息:' + e.data, alignment: DialogAlignment.Center })
  const req = http.createHttp()
  const res = await req.request('https://xxx/home/banner')
  //子线程给主线程发消息--将请求结果返回
  workerPort.postMessage(JSON.stringify(res))
  // 如果主线程没有关闭worker,主线程可以让worker自焚
  // workerPort.close() //自毁
}

/**
 * Defines the event handler to be called when the worker receives a message that cannot be deserialized.
 * The event handler is executed in the worker thread.
 *
 * @param e message data
 */
workerPort.onmessageerror = (e: MessageEvents) => {
}

/**
 * Defines the event handler to be called when an exception occurs during worker execution.
 * The event handler is executed in the worker thread.
 *
 * @param e error message
 */
workerPort.onerror = (e: ErrorEvent) => {
}

注意事项:
子线程在创建Worker时会自动生成文件,在生成的文件中处理逻辑。
在这里插入图片描述

四、效果展示

本次示例子线程给主线程发送了一个请求结果,我们用的是弹窗的形式展示
在这里插入图片描述
主线程给子线程发消息用的是控制台打印
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/945492.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Spring Cloud由入门到精通

文章目录 1.初识微服务1.1. 单体架构1.2.分布式架构1.3.微服务1.4 微服务技术比对1.5.Spring Cloud1.6. 总结2.服务拆分和远程调用2.1.服务拆分原则2.2.服务拆分示例2.2.1.项目工程结构设计2.2.2.创建Maven项目工程2.3.实现远程调用案例2.3.1.案例需求:2.3.2. 注册 Rest Templ…

电脑缺失libcurl.dll怎么解决?详解电脑libcurl.dll文件丢失问题

一、libcurl.dll文件丢失的原因 libcurl.dll是一个用于处理URL传输的库文件,广泛应用于各种基于网络的应用程序。当这个文件丢失时,可能会导致相关应用程序无法正常运行。以下是libcurl.dll文件丢失的一些常见原因: 软件安装或卸载不完整&a…

XIAO Esp32S3 播放网络Mp3

本文旨在使用XIAO Esp32S3 播放网络Mp3 所需硬件 max98357 接线 Xiao Esp32 S3Max983574LRC5BCLK 6DIN5VVinGNDGND代码: #include "Arduino.h" #include "WiFiMulti.h" #include "Audio.h"// Digital I/O used #def

自动驾驶新纪元:城区NOA功能如何成为智能驾驶技术的分水岭

目录 一、NOA 的定义 二、NOA 的主要特点 导航集成 场景覆盖 智能决策 高级感知能力 驾驶员参与 三、NOA 的优势 四、NOA的衡量指标 定性评价指标 安全性评价指标定义 可靠性评价指标定义 舒适性评价指标定义 通行效率评价指标 定量评价指标 五、代表厂商的实测…

直观解读 JuiceFS 的数据和元数据设计(一)

大家读完觉得有意义和帮助记得关注和点赞!!! 1 JuiceFS 高层架构与组件2 搭建极简 JuiceFS 集群 2.1 搭建元数据集群2.2 搭建对象存储(MinIO) 2.2.1 启动 MinIO server2.2.2 创建 bucket2.3 下载 juicefs 客户端2.4 创…

如何用jmeter工具进行性能测试

前言 今天我们来说说jmeter如何进行性能测试,我们都知道jmeter工具除了可以进行接口功能测试外,还可以进行性能测试。当项目趋于稳定,根据性能需求就可以着手准备性能测试了,今天就说一说jmeter如何进行性能测试,jmet…

《云原生安全攻防》-- K8s安全配置:CIS安全基准与kube-bench工具

在本节课程中,我们来了解一下K8s集群的安全配置,通过对CIS安全基准和kube-bench工具的介绍,可以快速发现K8s集群中不符合最佳实践的配置项,及时进行修复,从而来提高集群的安全性。 在这个课程中,我们将学习…

Web安全 - “Referrer Policy“ Security 头值不安全

文章目录 概述原因分析风险说明Referrer-Policy 头配置选项1. 不安全的策略no-referrer-when-downgradeunsafe-url 2. 安全的策略no-referreroriginorigin-when-cross-originsame-originstrict-originstrict-origin-when-cross-origin 推荐配置Nginx 配置示例 在 Nginx 中配置 …

《计算机组成及汇编语言原理》阅读笔记:p133-p159

《计算机组成及汇编语言原理》学习第 11 天,p133-p159 总结,总计 27 页。 一、技术总结 1.segment (1)定义 Broadly speaking, a contiguous section of memory. More specifically, a section of memory referenced by one of the segment register…

QT-----------GUI程序设计基础

项目配置文件 .pro文件:这是QT项目的核心配置文件,用于指定项目的名称、版本、源文件、头文件、库文件等信息。例如: QT core guigreaterThan(QT_MAJOR_VERSION, 4): QT widgetsCONFIG c11# The following define makes your comp…

爆改RagFlow

爆改RagFlow 一、Rag理论概述二、Ragflow解析参数说明三、♥ RagFlow源码解析核心代码流程梳理1、OCR识别2、版面分析3、parser功能3.1 PdfParser3.1.1 首先,初始化3.1.2 **pdf转图片** [来自工业界的知识库 RAG 服务(二),RagFlow 源码全流程深度解析](h…

实际部署Dify可能遇到的问题:忘记密码、开启HTTPS、知识库文档上传的大小限制和数量限制

背景 前面我们以 docker compose 容器化的方式本地部署了 Dify 社区版,并快速体验了其聊天助手、工作量编排以及智能体(Agent)功能。不过后续实际生产环境使用时遇到了忘记密码、如何开启SSL以支持HTTPS、如何突破知识库文档上传的大小限制和…

Ubuntu安装Apache Airflow详细指南

本文我们介绍如何在Ubuntu上安装Apache Airflow。Apache Airflow旨在通过编程方式编写、调度和监控工作流。随着数据编排在现代数据工程中变得越来越重要,掌握Apache Airflow等工具可以显著提高您的生产力和效率。 学习Apache Airflow的首要任务是安装单机版本进行测…

Learning Multi-Scale Photo Exposure Correction

Abstract 用错误的曝光捕捉照片仍然是相机成像的主要错误来源。曝光问题可分为以下两类:(i)曝光过度,即相机曝光时间过长,导致图像区域明亮和褪色;(ii)曝光不足,即曝光时间过短,导致图像区域变暗。曝光不足和曝光过度都会大大降低…

【python】matplotlib(moon cake)

文章目录 1、Style12、Style23、Style34、Style45、Style56、Style67、Style78、参考的库函数matplotlib.patches.Arcmatplotlib.patches.Wedge 9、参考 1、Style1 """ author: tyran """from numpy import sin, cos, pi import matplotlib.pyp…

node.js卸载并重新安装(超详细图文步骤)

卸载node.js 重新安装nodejs 一、卸载 1、首先进入控制面板卸载程序 2、卸载后 到文件夹中进行进一步的删除 删除上述的几个文件夹 每个人可能不一样,总之是找到自己的nodejs安装路径,下面是我的 ①删除C:UsersAdminAppDataRoaming路径下的npm相关文件…

每天40分玩转Django:Django表单集

Django表单集 一、知识要点概览表 类别知识点掌握程度要求基础概念FormSet、ModelFormSet深入理解内联表单集InlineFormSet、BaseInlineFormSet熟练应用表单集验证clean方法、验证规则熟练应用自定义配置extra、max_num、can_delete理解应用动态管理JavaScript动态添加/删除表…

抽奖2(信奥)

【问题描述】 公司举办年会,为了活跃气氛,设置了摇奖环节。参加聚会的每位员工都有一张带有号码的抽奖券。现在,主持人从小到依次公布了n个不同的获奖号码,小谢看着自己抽奖券上的号码win,无比紧张。请编写一个程序&am…

JWT包中的源码分析【Golang】

前言 最近在学web编程的途中,经过学长提醒,在进行登陆(Login)操作之后,识别是否登陆的标识应该要放入authorization中,正好最近也在学鉴权,就顺便来看看源码了。 正文 1. 代码示例 在进行分…

Airbnb/Booking 系统设计(high level architecture)

原文地址 CodeKarle: Airbnb System Design | Booking.com System Design B站搜 “Airbnb System Design” 有视频版本 需求: 功能性需求 系统用户包括商家和客人。 Hotel - 商家(拥有hotel的人) onboarding - 商家可以入住系统。 update…