美文网首页
ReactNative 任务队列

ReactNative 任务队列

作者: li_礼光 | 来源:发表于2021-04-13 21:45 被阅读0次

需求 :
相册功能分云端和本地, 批量下载云端数据的时候, 每完成一个, 重新获取一遍新的本地数据, 刷新本地列表.

注意点:
1.批量下载云端数据, 每一个下载耗时可能很短, 比如一个1M大小的资源, 0.5s就下载完成.
2.重新获取本地数据并且刷新, 异步执行, 耗时操作, 1s完成一次
3.多次获取本地数据的任务如果没有按序执行, 可能导致数据不同步, 或者数据错乱.


1.创建队列属性

  constructor(props) {
    super(props);
    // 通过队列的方式, 控制刷新, 确保数据的准确性
    this.getLocalAlbumDataQueue = [];
    this.getLocalAlbumDataQueue.active = false;
    this.targetResult = 0;
  }

2.创建添加队列任务方法

  // 需要做一个队列控制getLocalAlbumData的处理. 每次下载完之后, 需要按序重新获取数据源
  /**
   * 添加到任务队列
   */
   addToLocalAlbumDataQueue = (task) => {
     this.getLocalAlbumDataQueue.push({ task });
     if (!this.getLocalAlbumDataQueue.active) {
       this.next();
     }
   }

3.创建下一步执行方法

/**
   * 顺序执行任务
   */
  next = () => {
    if (!this.getLocalAlbumDataQueue.length) {
      this.getLocalAlbumDataQueue.active = false;
      return;
    }

    const { task } = this.getLocalAlbumDataQueue.shift();
    this.getLocalAlbumDataQueue.active = true;
    task().then(() => {
      console.log('执行完成');
      console.log('!!!!!!!!!!!!!!!!! this.targetResult : ', this.targetResult);
      this.next();
    }).catch((err) => {
      console.log('执行失败 : ', err);
    });
  }

4.创建Promise任务方法


  funcPromiseTask =() => {
    const task = new Promise((resolve, reject) => {
      if (this.targetResult === -1) {
        reject();
      }
      this.targetResult += 1;
      resolve();
    });
    return task;
  }


测试 : 多个异步耗时任务执行

  funcTest = () => {
    this.addToLocalAlbumDataQueue(this.funcPromiseTask);
    this.addToLocalAlbumDataQueue(this.funcPromiseTask);
    this.addToLocalAlbumDataQueue(this.funcPromiseTask);
    this.addToLocalAlbumDataQueue(this.funcPromiseTask);
    this.addToLocalAlbumDataQueue(this.funcPromiseTask);
    this.addToLocalAlbumDataQueue(this.funcPromiseTask);
    this.addToLocalAlbumDataQueue(this.funcPromiseTask);
    ....
  }

结果 : 多个异步耗时任务执行

PS :

这里funcPromiseTask看起来不是耗时计算, 异步操作的方法内容, 换一个异步的方法也是一样的效果.

总结 :

使用Promise的方式, 创建按序执行的任务队列

相关文章

  • ReactNative 任务队列

    需求 :相册功能分云端和本地, 批量下载云端数据的时候, 每完成一个, 重新获取一遍新的本地数据, 刷新本地列表...

  • 同步任务队列、宏观任务队列、微观任务队列

    1、JS是单线程语言,包括同步任务、异步任务,异步任务又包括宏观任务和微观任务 2、执行顺序:同步任务——>微观任...

  • 同步任务队列、宏观任务队列、微观任务队列

    1、JS是单线程语言,包括同步任务、异步任务,异步任务又包括宏观任务和微观任务 2、执行顺序:同步任务——>微观任...

  • 关于GCD中的队列、线程、任务之间的关系及死锁的理解

    1. 任务与队列之间的关系 任务产生后被加入到某个队列中,队列仅保管任务,不执行任务; 队列分为串行队列和并行队列...

  • js运行机制

    在运行时会形成任务队列,分为同步任务队列和异步任务对列,同步队列优先加载异步任务队列会形成队列任务池,定时器不会一...

  • 2018-06-08 宏任务和微任务

    js先把宏任务放进宏任务队列里,再把微任务放进微任务队列里,执行的时候先执行宏任务队列里的一个任务,再把微任务队列...

  • GCD总结

    一.队列:这里的队列指执行任务的等待队列,即用来存放任务的队列。 二.在队列中加入任务1.队列中 添加 异步调用的...

  • nextTick、setImmediate、promise.re

    执行队列(同步) 任务队列(异步事件) 每当异步任务完成后会在任务队列中添加一个关联事件,待执行队列任务执行完成...

  • Redis入门(5) - 消息通知

    使用列表实现任务队列 优先级队列 按照规则订阅 Redis也可以作为任务队列。任务队列顾名思义,就是“传递任务的队...

  • 多线程02

    多线程2 GCD队列组: 基本使用: 常用函数 队列和组队列的区别 队列:封装任务,添加任务到队列 组队列:封装任...

网友评论

      本文标题:ReactNative 任务队列

      本文链接:https://www.haomeiwen.com/subject/kopwhltx.html