前言
年前公司与华为签订了互助备忘录,加入了鸿蒙生态这个大家庭。。公司想赶着鸿蒙纯血系统上市之前,发布自己的鸿蒙软件。开辟鸿蒙NEXT版本软件就变成了今年的一个工作重心。
本文主要讲授开辟过程中遇到的并发题目,官方API 11文档写的太简单了,根本没有办理方案,小编也是苦思冥想,绞尽脑汁才找到办理方案。需要开辟鸿蒙的小伙伴可以细致阅读,避免踩坑。
题目
在开辟扫除缓存的功能时,鸿蒙NEXT提供的文档中说明,应用缓存文件有四个,需要扫除指定的四个缓存文件夹。如图所示:
扫除缓存代码如下:
登录后复制 - import fs from '@ohos.file.fs'
-
- fs.access("文件路径").then((isHas:boolean) => {
- if(isHas) { //判断文件是否存在
- fs.rmdirSync("文件路径")//删除文件
-
- }
- })
复制代码
需要同时扫除这四个文件夹,然后再计算这四个文件夹的大小。由于fs.access 方法是耗时操作。所以只能在异步线程中实行。
办理方案
一般思绪
鸿蒙官方文档API 11 提供了使用Promise和async/await处理异步并发题目。
注意是单次I/O使命,可题目是我们需要办理同时并发题目,一次拿到四次扫除缓存结果再去统计缓存大小。这个时间可能有的小伙伴就会说,那就先扫除第一个,等一个结果返回再扫除第二个,以此类推。也能办理题目。如下图所示:
登录后复制 - fs.access("文件路径1").then((isHas:boolean) => {
- if(isHas) { //判断文件是否存在
- fs.rmdirSync("文件路径1")//删除文件
-
- fs.access("文件路径2").then((isHas:boolean) => {
- if(isHas) { //判断文件是否存在
- fs.rmdirSync("文件路径2")//删除文件
- .....................
- }
- })
- }
- })
复制代码
- 1.
- 2.
- 3.
- 4.
- 5.
- 6.
- 7.
- 8.
- 9.
- 10.
- 11.
- 12.
但是这样就会带来两个题目:多层嵌套与代码混乱。在Flutter中这个题目非常好办理。这里就不具体描述了。
优雅方案
使用Promise.all 办理。小编在官方文档中并没有找到Promise.all 相干说明,可能是鸿蒙还没注意到这种需求场景吧。直接上代码。
登录后复制 - asyncClear(dir: string): Promise<void> {
- return new Promise((resolve, reject) => {
- fs.access(dir).then((isHas: boolean) => {
- if (isHas) {
- fs.rmdir(dir)
- }
- resolve()
- })
- })
- }
复制代码
- 1.
- 2.
- 3.
- 4.
- 5.
- 6.
- 7.
- 8.
- 9.
- 10.
登录后复制 - let promises= [
- this.asyncClear("文件夹1"),
- this.asyncClear("文件夹2"),
- this.asyncClear("文件夹3"),
- this.asyncClear("文件夹4")
- ]
复制代码
- 将使命数组放进Promis.all中,等候四个使命实行竣事。
登录后复制 - Promise.all(promises).then(() => {
- // 结束回调
- })
复制代码
登录后复制 - storageStatistics.getCurrentBundleStats().then((bundleStats) => {
- let cacheSizeNum = bundleStats.cacheSize
- let unit = "KB"
- if (cacheSizeNum > 1024) {
- cacheSizeNum = Math.floor(cacheSizeNum) / 1024
- unit = "KB"
- }
- if (cacheSizeNum > 1024) {
- cacheSizeNum = Math.floor(cacheSizeNum) / 1024
- unit = "MB"
- }
- if (cacheSizeNum > 1024) {
- cacheSizeNum = Math.floor(cacheSizeNum) / 1024
- unit = "GB"
- }
- if (cacheSizeNum > 1024) {
- cacheSizeNum = Math.floor(cacheSizeNum) / 1024
- unit = "TB"
- }
- let chacheSizeString = "" + Math.floor(cacheSizeNum) + unit
- });
复制代码
- 1.
- 2.
- 3.
- 4.
- 5.
- 6.
- 7.
- 8.
- 9.
- 10.
- 11.
- 12.
- 13.
- 14.
- 15.
- 16.
- 17.
- 18.
- 19.
- 20.
- 21.
总结
鸿蒙NEXT的API还不算完善,需要每个开辟者的加入,发现题目,提出题目,鸿蒙开辟人员才气更好的办理题目。如果您也是鸿蒙开辟者,有其他更好的办理方案,接待评论区交流 ,互相学习,互相成长!
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |