开天辟地 HarmonyOS(鸿蒙) - ArkTS 多线程: Worker(工作线程)

源码 https://github.com/webabcd/HarmonyDemo
作者 webabcd

开天辟地 HarmonyOS(鸿蒙) - ArkTS 多线程: Worker(工作线程)

示例如下:

pages\arkts\concurrent\WorkerDemo.ets

/** Worker - 工作线程*   需要手动管理*   线程之间的通信是基于消息传递的,传递的消息必须是可序列化的** 自动创建 worker 线程文件的方法:打开 DevEco Studio 然后依次点击 File -> New -> Worker* 手动创建 worker 线程文件的方法:* 1、在 /src/main/ets/ 目录层级之下创建一个 .ets 文件,本例创建的文件是 /src/main/ets/workers/myworker.ets* 2、编辑 build-profile.json5 文件,并添加类似如下的内容* {*   "apiType": "stageMode",*   "buildOption": {*     "sourceOption": {*       "workers": [*         './src/main/ets/workers/myworker.ets'*       ]*     }*   }* }*** 注:* 1、无法用 Previewer 测试 Worker,需要用模拟器或真机* 2、关于 Promise 和 async/await 请参见 arkts/advanced/Promise.ets, arkts/advanced/AsyncAwait.ets 中的相关说明*/import { TitleBar } from '../../TitleBar';
import { worker, MessageEvents, ErrorEvent } from '@kit.ArkTS';@Entry
@Component
struct WorkerDemo {@State message:string = ""build() {Column({space:10}) {TitleBar()Text(this.message).fontSize(16)Button("click me").fontSize(16).onClick(() => {this.message += `start\n`// 通过指定的 worker 线程文件创建工作线程对象(注:此处的文件路径要省略 src/main/)let threadWorker = new worker.ThreadWorker('entry/ets/workers/myworker.ets');// 接收到工作线程传递过来的消息后的回调threadWorker.onmessage = (e: MessageEvents) => {// e.data 就是工作线程传递过来的消息this.message += `onmessage:${e.data}\n`}// 工作线程被销毁后的回调(code 为 0 代表正常退出,code 为 1 代表异常退出)threadWorker.onexit = (code: number) => {this.message += `onexit:${code}\n`}// 工作线程运行中出现异常后的回调threadWorker.onerror = (err: ErrorEvent) => {this.message += `onerror:${err.message}\n`}// 传递指定的消息给工作线程threadWorker.postMessage("main to worker");})}}
}

\entry\src\main\ets\workers\myworker.ets

import { worker, ThreadWorkerGlobalScope, MessageEvents } from '@kit.ArkTS';// 创建一个用于当前工作线程与宿主线程之间通信的对象
const workerPort: ThreadWorkerGlobalScope = worker.workerPort;// 接收到宿主线程传递过来的消息后的回调
workerPort.onmessage = async (e: MessageEvents) => {await new Promise<void>((r) => { setTimeout(r, 1000) })// e.data 就是工作线程传递过来的消息let message = e.data as string// 传递指定的消息给宿主线程workerPort.postMessage(`receive:${e.data}, send:worker to main`)// 销毁当前工作线程workerPort.close();
}

源码 https://github.com/webabcd/HarmonyDemo
作者 webabcd

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

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

相关文章

AI应用示例:用AI通过单张面部照片预测您的职业与受教育程度

AI 生成的图像 | Flux Labs AI 制作想象一下,你走进一场面试,还没开口,AI 面试官就已经根据你的脸对你做出评估。这是不是 “以貌取人 2.0”?这算是歧视吗?还是 AI 正在推动一种新的 “面相主义”(face-ism)? 最近,来自多所大学的研究人员进行了一项研究,他们声称 AI…

电脑本地部署deepseek教程

Ollama:本地大模型运行指南奇舞精选2024-04-2814,445阅读11分钟关注 智能总结 复制 重新生成 这篇文章主要介绍了本地大模型运行框架 Ollama。包括其简介、安装方法(下载安装及大模型下载)、终端对话(如显示帮助、模型信息等命令)、API 调用(generate 和 chat 两…

可能是对春节假期的一些总结

写在前面2603 字 | 总结 | 经历 | 思考 | 感触未经允许,禁止转载。 正文「我一直都应该知道,听到别人说出她的名字,我还是会心里一跳。」过年与我当初预计的完全不同。我当初的计划,春节七八天,写很多很多文章,极速推进今年年度计划的写作一项。为此还专门订阅了一个月的…

搜狗录音笔c1折腾

1.买的pdd厂家帮我整好了大部分(应该刷过固件) 2.遇到的问题就是c to c的线...它没有协商,得插电脑usb-a口上才能识别到 3.厂家提供的搜狗录音笔助手这个软件是有点小处理的不是原软件(指解锁登录,其他的没看出问题,至少软件没报毒)

task3

任务二:Smiling-Weeping-zhr/Travel-assistant 自建项目链接,有关大模型关于大模型解答旅游相关

1.4 条件分支和循环机制

程序的流程分为顺序执行、条件分支和循环三种 顺序执行是按照地址内容的顺序执行指令。 条件分支是根据条件执行任意地址的指令。 循环是指重复执行同一地址的指令。 顺序执行每执行一个指令程序计数器的值自动加1条件分支和循环中使用的跳转指令,会参照当前执行的运算结果来判…

vue3使用flv.js播放flv直播流

目前有个需求是:管理直播机有一个列表需要查看每个直播机的实时内容,所以需要在后台加这个功能。 效果:我用ffmpeg模拟推流: 如何用ffmpeg模拟推流请看我上一篇文章 网页: 如上是可以正确再网页端拉流,这个功能费了一天的时间,在这里免费分享出来。 首先安装flv.js(用n…

DeepSeep本地部署

1、浏览器搜索引擎更改 2、搜索:Ollama操作下载: 也可直接进入下载路径:https://ollama.com/download/windows ollama run deepseek-r1 本文来自博客园,作者:他还在坚持嘛,转载请注明原文链接:他还在坚持嘛 https://www.cnblogs.com/brf-test/p/18699050

Linux下使用df与du命令查看磁盘空间

1、df磁盘空间查看df可以查看一级文件夹大小、使用比例、档案系统及其挂入点。[root@oms ~]# df -Th Filesystem Type Size Used Avail Use% Mounted on /dev/vda1 ext4 40G 35G 3.1G 92% / devtmpfs devtmpfs 1.9G 0 1.9G 0% /dev tmp…

JOKER智能可视化平台 20250204版本更新说明

本次 JOKER 低代码平台更新涵盖了代码生成、环境变量、可视化开发工具等多个关键领域的优化与新增功能,致力于为开发者提供更高效、更安全、更便捷的开发体验。同时,服务端功能的正式发布以及核心升级,进一步增强了平台的整体性能和竞争力。 一、功能更新与优化 (一)代码生…

城市智慧升级:超算与智算的协同效应

随着数字化转型的不断深入,城市高质量发展越来越依赖于强大的算力支持。结合超级计算(超算)和智能计算(智算)的“超算+智算”模式,正在成为推动城市创新和智能化发展的重要力量。超算与智算的结合超级计算通常指的是使用最先进的计算机硬件和软件进行大规模科学计算的技术…