promise任務(wù)隊(duì)列串行化執(zhí)行

js經(jīng)常會遇到異步的執(zhí)行,簡單的異步執(zhí)行可以使用回調(diào)峰伙,多個(gè)異步回調(diào)執(zhí)行可以使用await/async解決疗疟。遇到多個(gè)不定的異步需要同步一個(gè)一個(gè)執(zhí)行的時(shí)候,無法直接執(zhí)行瞳氓,例如多個(gè)網(wǎng)絡(luò)請求策彤,需要一個(gè)一個(gè)去執(zhí)行,就會遇到任務(wù)隊(duì)列串行執(zhí)行的問題匣摘。
在遇到多個(gè)需要異步執(zhí)行的promise時(shí)店诗,可以直接使用promise提供了all方法同時(shí)執(zhí)行多個(gè)promise,但是并未能解決異步的任務(wù)是不斷產(chǎn)生的情況音榜。在異步任務(wù)不斷產(chǎn)生而且需要順序的執(zhí)行完一個(gè)才能執(zhí)行下一個(gè)的情況下庞瘸。使用定時(shí)器和隊(duì)列來解決,新任務(wù)加入隊(duì)列赠叼,隊(duì)列不斷拿出任務(wù)執(zhí)行擦囊,就可以做到串行化執(zhí)行了。

export interface PromiseQueueOptions {
  interval?: number;
}

export default class PromiseQueue {
  private interval?: any;
  // 選項(xiàng)
  private options: PromiseQueueOptions;
  // 鎖定
  private lock = false;
  // 隊(duì)列
  private queue: (() => Promise<any>)[] = [];
  static instance(options: PromiseQueueOptions = {}): PromiseQueue {
    if (options.interval == undefined) options.interval = 200;
    return new PromiseQueue(options);
  }
  constructor(options: PromiseQueueOptions) {
    this.options = options;
    this.interval = setInterval(async () => {
      // 沒有任務(wù)或者任務(wù)執(zhí)行中情況不執(zhí)行
      if (this.queue.length > 0 && !this.lock) {
        console.log('execute queue');
        // 鎖定
        this.lock = true;
        // 取出函數(shù)
        const f = this.queue.shift();
        // 解鎖
        await f!();
        this.lock = false;
      }
    }, options.interval);
  }
  // 加入隊(duì)列
  push(f: () => Promise<any>) {
    this.queue.push(f);
  }
  // 釋放隊(duì)列
  destory() {
    clearInterval(this.interval);
  }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末梅割,一起剝皮案震驚了整個(gè)濱河市霜第,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌户辞,老刑警劉巖泌类,帶你破解...
    沈念sama閱讀 211,639評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異底燎,居然都是意外死亡刃榨,警方通過查閱死者的電腦和手機(jī)双仍,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來朱沃,“玉大人茅诱,你說我怎么就攤上這事“嶙洌” “怎么了?”我有些...
    開封第一講書人閱讀 157,221評論 0 348
  • 文/不壞的土叔 我叫張陵契邀,是天一觀的道長。 經(jīng)常有香客問我坯门,道長微饥,這世上最難降的妖魔是什么古戴? 我笑而不...
    開封第一講書人閱讀 56,474評論 1 283
  • 正文 為了忘掉前任欠橘,我火速辦了婚禮,結(jié)果婚禮上允瞧,老公的妹妹穿的比我還像新娘简软。我一直安慰自己,他們只是感情好述暂,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,570評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著建炫,像睡著了一般畦韭。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上肛跌,一...
    開封第一講書人閱讀 49,816評論 1 290
  • 那天艺配,我揣著相機(jī)與錄音,去河邊找鬼衍慎。 笑死转唉,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的稳捆。 我是一名探鬼主播赠法,決...
    沈念sama閱讀 38,957評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼乔夯!你這毒婦竟也來了砖织?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,718評論 0 266
  • 序言:老撾萬榮一對情侶失蹤末荐,失蹤者是張志新(化名)和其女友劉穎侧纯,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體甲脏,經(jīng)...
    沈念sama閱讀 44,176評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡眶熬,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,511評論 2 327
  • 正文 我和宋清朗相戀三年妹笆,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片娜氏。...
    茶點(diǎn)故事閱讀 38,646評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡晾浴,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出牍白,到底是詐尸還是另有隱情脊凰,我是刑警寧澤,帶...
    沈念sama閱讀 34,322評論 4 330
  • 正文 年R本政府宣布茂腥,位于F島的核電站狸涌,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏最岗。R本人自食惡果不足惜帕胆,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,934評論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望般渡。 院中可真熱鬧懒豹,春花似錦、人聲如沸驯用。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,755評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蝴乔。三九已至记餐,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間薇正,已是汗流浹背片酝。 一陣腳步聲響...
    開封第一講書人閱讀 31,987評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留雕沿,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,358評論 2 360
  • 正文 我出身青樓审轮,卻偏偏與公主長得像宁脊,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子榆苞,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,514評論 2 348

推薦閱讀更多精彩內(nèi)容