数组耗时操作按顺序执行 HarmonyOS 鸿蒙Next
数组耗时操作按顺序执行 HarmonyOS 鸿蒙Next
这边有一个图片数组,包含图片123 我需要先按顺序吧图片传给服务器,等所有图片传递完后,再显示成功视图 想请教下如何保证图片传递顺序,即图1传完后传图2,完后再传图3,最后显示成功视图, 如下这种forEach 既不能保证 123按顺序,也不能保证 所有图都传完了后再
picFileList: Array<string> = [];
upload() {
this.picFileList.forEach(async (uri: string,
index: number) => { // 执行一些耗时操作,耗时各不一样,可能1s 可能2s
const imageVO = await HttpHelper.uploadImage(uri)
})
showSuc()
}
更多关于数组耗时操作按顺序执行 HarmonyOS 鸿蒙Next的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html
@Concurrent
function additionDelay(delay:number): void {
let start: number = new Date().getTime();
while (new Date().getTime() - start < delay) {
continue;
}
}
@Concurrent
function waitForRunner(finalString: string): string {
return finalString;
}
async function seqRunner()
{
let finalString:string = "";
let task1:taskpool.Task = new taskpool.Task(additionDelay, 3000);
let task2:taskpool.Task = new taskpool.Task(additionDelay, 2000);
let task3:taskpool.Task = new taskpool.Task(additionDelay, 1000);
let task4:taskpool.Task = new taskpool.Task(waitForRunner, finalString);
let runner:taskpool.SequenceRunner = new taskpool.SequenceRunner();
runner.execute(task1).then(() => {
finalString += ‘a’;
console.info(“seqrunner: task1 done.”);
});
runner.execute(task2).then(() => {
finalString += ‘b’;
console.info(“seqrunner: task2 done”);
});
runner.execute(task3).then(() => {
finalString += ‘c’;
console.info(“seqrunner: task3 done”);
});
await runner.execute(task4);
console.info("seqrunner: task4 done, finalString is " + finalString);
}
更多关于数组耗时操作按顺序执行 HarmonyOS 鸿蒙Next的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html
两种方案:
1、编写一个递归方法进行请求
2、通过开辟线程,执行顺序请求
在HarmonyOS鸿蒙Next中处理数组耗时操作时,如果需按顺序执行,可以采用任务队列或消息队列机制。
鸿蒙提供了分布式任务调度能力,可以利用该能力将耗时操作封装为任务,并依次添加到任务队列中。每个任务执行完成后,自动触发下一个任务的执行。这种方式能够确保任务按顺序执行,同时不会阻塞主线程。
此外,鸿蒙的消息队列机制也可以实现类似功能。将耗时操作封装为消息,按顺序发送到消息队列中。消息队列按照先进先出的原则处理消息,从而确保操作按顺序执行。
在具体实现时,可以创建一个全局的任务队列或消息队列,并在需要执行耗时操作时,将操作封装为任务或消息,添加到队列中。同时,需要一个任务或消息处理循环,不断从队列中取出任务或消息并执行。
需要注意的是,由于耗时操作可能会占用较长时间,因此在实际应用中,建议将耗时操作放在后台线程或异步任务中执行,以避免阻塞主线程,影响用户界面的响应速度。
如果上述方法仍无法满足需求,或遇到其他问题,请直接联系官网客服。官网地址是:https://www.itying.com/category-93-b0.html 。