当前位置: 首页 > news >正文

软件公司招聘网站林萌荣温州市网页制作

软件公司招聘网站,林萌荣温州市网页制作,有口碑的宜昌网站建设,wordpress别名介绍 本示例介绍在Worker 子线程使用ohos.zlib 提供的zlib.decompressfile接口对沙箱目录中的压缩文件进行解压操作,解压成功后将解压路径返回主线程,获取解压文件列表。 效果图预览 使用说明 1.点击解压按钮,解压test.zip文件&#xff0c…

介绍

本示例介绍在Worker 子线程使用@ohos.zlib 提供的zlib.decompressfile接口对沙箱目录中的压缩文件进行解压操作,解压成功后将解压路径返回主线程,获取解压文件列表。

效果图预览

在这里插入图片描述
使用说明

1.点击解压按钮,解压test.zip文件,显示解压结果。

实现思路

1.在/src/main/ets/workers目录下创建Worker.ets线程文件,绑定Worker对象。

const workerPort: ThreadWorkerGlobalScope = worker.workerPort;

2.在build-profile.json5中进行配置Worker线程文件路径,Worker线程文件才能确保被打包到应用中。

"buildOption": {"sourceOption": {"workers": ["./src/main/ets/workers/Worker.ets"]}
}

3.在主线程创建一个Worker线程,通过new worker.ThreadWorker()创建Worker实例,传入Worker.ets的加载路径。

let workerInstance: worker.ThreadWorker = new worker.ThreadWorker('@decompressFile/ets/workers/Worker.ets');

4.主线程使用postMessage()向worker线程发送应用沙箱路径和压缩文件名称。

workerInstance.postMessage({ pathDir: this.pathDir, rawfileZipName: rawfileZipName });

5.在Worker.ets文件中通过调用onmessage()方法接收主线程发送的应用沙箱路径和压缩文件名称。

workerPort.onmessage = (e: MessageEvents): void => {logger.info(TAG, `Worker onmessage:${JSON.stringify(e.data)}`);let pathDir: string = e.data.pathDir; // 沙箱目录let rawfileZipName: string = e.data.rawfileZipName; // 带.zip后缀的压缩文件名称
}

6.使用fs.access判断输出目录是否已经存在,如果不存在使用fs.mkdirSync()创建空目录用于放置解压后的文件。空目录创建成功后使用zlib.decompressFile接口解压压缩文件,输出到空目录中。

fs.access(outFileDir).then((res: boolean) => {if (!res) {// TODO:知识点:使用fs.mkdirSync创建目录,用于存放解压后的文件。fs.mkdirSync(outFileDir);logger.info(TAG, 'mkdirSync succeed');}// TODO:知识点:使用zlib.decompressfile接口对沙箱目录中的压缩文件进行解压操作,解压至指定沙箱目录outFileDir。// 如果待解压的文件或文件夹在解压后的路径下已经存在,则会直接覆盖同名文件或同名文件夹中的同名文件。zlib.decompressFile(`${pathDir}/${rawfileZipName}`, outFileDir, (errData: BusinessError) => {if (errData !== null) {logger.error(TAG, `decompressFile failed. code is ${errData.code}, message is ${errData.message}`);} else {logger.info(TAG, `decompressFile succeed. outFileDir is ${outFileDir}`);// TODO:知识点:Worker线程向主线程发送信息。workerPort.postMessage(outFileDir);}})
}).catch((err: BusinessError) => {logger.error(TAG, `access failed with error message: ${err.message}, error code: ${err.code}`);
});

高性能知识点

  1. 本示例使用了LazyForEach进行数据懒加载,List布局时会根据可视区域按需创建ListItem组件,并在ListItem滑出可视区域外时销毁以降低内存占用。
  2. 本示例使用在Work子线程中使用zlib.decompressFile解压文件,避免阻塞主线程的运行。

工程结构&模块类型

decompressFile                                // har类型
|---/src/main/ets/model                        
|   |---FileListDataSource.ets                // 数据模型层-列表数据模型 
|   |---FileItemModel.ets                     // 数据模型层-列表项数据模型
|---/src/main/ets/view                        
|   |---MainPage.ets                          // 视图层-场景列表页面
|---/src/main/ets/workers                        
|   |---Worker.ets                            // Worker线程

模块依赖

1.本实例依赖common模块来获取日志工具类logger。

如果大家还没有掌握鸿蒙,现在想要在最短的时间里吃透它,我这边特意整理了《鸿蒙开发学习手册》(共计890页),希望对大家有所帮助:https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

《鸿蒙开发学习手册》:

如何快速入门:https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

1.基本概念
2.构建第一个ArkTS应用
3.……

在这里插入图片描述

开发基础知识:https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

1.应用基础知识
2.配置文件
3.应用数据管理
4.应用安全管理
5.应用隐私保护
6.三方应用调用管控机制
7.资源分类与访问
8.学习ArkTS语言
9.……

在这里插入图片描述

基于ArkTS 开发:https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

1.Ability开发
2.UI开发
3.公共事件与通知
4.窗口管理
5.媒体
6.安全
7.网络与链接
8.电话服务
9.数据管理
10.后台任务(Background Task)管理
11.设备管理
12.设备使用信息统计
13.DFX
14.国际化开发
15.折叠屏系列
16.……

在这里插入图片描述

鸿蒙语法ArkTS、TypeScript、ArkUI等…视频教程:https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

在这里插入图片描述

鸿蒙生态应用开发白皮书V2.0PDF:https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

在这里插入图片描述

HarmonyOS APP开发教程案列:https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

在这里插入图片描述

http://www.yayakq.cn/news/494257/

相关文章:

  • wordpress模板调用自定义插件成都网站排名优化报价
  • 东营建设网站开锁行业在58做网站有活吗
  • 广东网站建设公司排名在哪个网站注册域名
  • 动漫网站设计与实现做购物网站实例代码
  • 可以做c语言任务的网站wordpress换域名搬家
  • 做加油机公司网站wordpress 后端是什么
  • 做签证宾馆订单用啥网站网站建设与优化及覆盖率方案
  • 建设网站转赚钱吗网站怎么做优化排名
  • 微信怎么注册公众号百度快照优化
  • 建站成功是怎么回事图片转视频在线制作
  • 做企业门户网站免费asp网站源码
  • 网站是怎么优化的做芯片哪个网站推广
  • 南宁市住房和城乡建设局网站网络服务器搭建与配置
  • 为企业为什么做网站游戏软件开发流程
  • 网站建设淘宝客模板人社网站和微信平台建设方案
  • 大连 响应式网站制作wordpress房产
  • 宁波做网站公司百度网络小说排行榜
  • 珠海网站建设优化推广wordpress主题公园下载
  • 产品网站系统网站系统改教程
  • 北京最好的网站制作公司公众号开发菜单
  • 网站开发的国内外现状江西短视频搜索seo推荐
  • 新网站关键词怎么优化小说关键词搜索器
  • 简述电子商务网站的内容设计与开发深圳做棋牌网站建设找哪家公司好
  • 网站seo设计linode搭建wordpress
  • 广州工程建设网站90设计网官网首页
  • 示范高校建设网站相亲网站开发与设计报告
  • wordpress中文文章排版插件沈阳seo网站推广
  • 邯郸网站建设做公司宁夏省建设厅网站
  • 进一步强化网站建设微信app下载安装2024最新版
  • 漯河市源汇区网站建设莱芜公交网站