145 Star 1.4K Fork 1.7K

OpenHarmony/applications_app_samples

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README

多线程任务

介绍

本示例通过@ohos.taskpool@ohos.worker 接口,展示了如何启动worker线程和taskpool线程。

效果预览

首页 拷贝文件 worker页面 任务池页面

使用说明

  1. 在主界面,可以点击字符串排序拷贝文件按钮进入对应的界面;

  2. 点击字符串排序按钮进入多线程界面:

    worker:

    1. 选择Worker页签,输入待排序的字符串,并以逗号分割。

    2. 点击字符串排序按钮,会将排序前的字符串发送给worker线程,在worker线程实现字符串排序,然后将排序后的字符串发送给主线程,主线程中显示排序后的字符串。

    3. 点击清除按钮,清除字符串。

    taskpool:

    1. 选择TaskPool页签,输入待排序的字符串,并以逗号分割。

    2. 选择添加至任务组按钮,将当前字符串的排序任务添加至任务组。

    3. 点击立即执行按钮,如之前有添加至任务组操作则任务组执行完成后将排序后的字符串显示出来;如没有上述操作则执行当前任务完成,将排序后的字符串显示出来。

    4. 点击超时3s执行按钮,任务延迟3s后执行,执行完成后将排序后的字符串显示出来。

    5. 点击函数任务按钮,直接调用执行操作,执行完成后将排序后的字符串显示出来。需要注意的是,通过函数任务创建的task任务不支持取消。

    6. 点击取消任务按钮,会取消最后一个未执行的task任务。需要注意的是,只有当任务数大于最大线程数且任务未开始执行时才可以取消成功。

    7. 点击清除按钮,清除字符串。

    8. 点击传递SendableClass按钮,内存共享方式传递SendableClass。

  3. 点击拷贝文件按钮进入文件拷贝界面:

    选择需要拷贝的文件,然后点击拷贝文件按钮,文件拷贝成功,触发事件日志显示沙箱下文件个数以及显示部分拷贝成功的文件名。

工程目录

entry/src/main/ets/
|---common
|   |---Common.ets                       // 公用方法,如bufferToString
|   |---Logger.ts                       // 日志
|---component
|   |---SendableTest.ets                 // 传递SendableClass页签
|   |---TaskPoolTab.ets                 // taskpool页签
|   |---test.ets                        // Sendable Class
|   |---WorkerTab.ets                   // worker页签
|---entryability
|---fileFs
|   |---MyWorker.ets                    // 批量拷贝文件
|---pages
|   |---CopyFile.ets                    // 拷贝文件界面,可选择把文件进行拷贝并显示触发事件后日志
|   |---Index.ets                       // 首页
|   |---StrSort.ets                     // worker和taskpool页签都在这里调用
|---workers
|   |---Worker.ts                       // worker线程
|   |---WorkerCopy.ts                   // 拷贝文件的worker线程

具体实现

  • worker页签的实现在字符串排序页面调用,源码参考StrSort.ets

    • 字符串排序:通过调用executeWorkerFunc()创建一个worker线程,把待排序字符串发送给worker线程,等worker线程排序完成后再把结果返回。
    • 清除:把字符串输入框和结果都清除。
  • taskpool页签的实现在字符串排序页面调用,源码参考StrSort.ets

    • 立即执行:如没有添加至任务组操作,通过调用executeImmediately()创建一个task任务,这个任务是立即执行字符串排序;如先进行了添加至任务组操作,则通过调用executeImmediately()将任务组执行完毕。
    • 超时3s执行:通过调用executeDelay()创建一个task任务,这个任务是延迟3s后执行字符串排序。
    • 函数任务:调用executeFunc()接口,不创建task任务,直接调用taskpool.execute()执行字符串排序。
    • 取消任务:调用cancelTask()接口,取消最后一个未执行的task任务。
    • 清除:把字符串输入框和结果都清除。
    • 添加至任务组:调用addTask()接口,将当前任务添加至任务组。
  • 内存共享的实现在taskpool页面调用,源码参考TaskPoolTab.ets

  • 批量拷贝文件的功能封装在MyWorker,源码参考:MyWorker.ets

    • 拷贝文件:在CopyFile.ets

      中调用MyWorker.WorkToCopyFiles(),在WorkToCopyFiles方法中向WorkerCopy线程发消息,并在WorkerCopy线程中批量拷贝,拷贝完成后将结果返回。

相关权限

不涉及。

依赖

不涉及。

约束与限制

1.本示例仅支持标准系统上运行, 支持设备:RK3568;。

2.本示例为Stage模型,支持API12版本SDK,版本号:5.0.0.21,镜像版本号:OpenHarmony 5.0.0.21。

3.本示例需要使用DevEco Studio NEXT Developer Preview1 (Build Version: 4.1.3.501, built on February 5, 2024)及以上版本才可编译运行。

下载

如需单独下载本工程,执行如下命令:

git init
git config core.sparsecheckout true
echo code/LanguageBaseClassLibrary/ConcurrentModule/ > .git/info/sparse-checkout
git remote add origin https://gitee.com/openharmony/applications_app_samples.git
git pull origin master
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/openharmony/applications_app_samples.git
git@gitee.com:openharmony/applications_app_samples.git
openharmony
applications_app_samples
applications_app_samples
master

搜索帮助