成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

還在找什么,JavaScript的異步編程解決方案全在這里了

開發 前端
JavaScript的特點就是單線程,本文首先對單線程異步的原理進行了解讀,接著著重分析了JavaScript異步解決方案,詳述了Callback、Promise、Generator、Async/Await的特性和使用原理。

阿里巴巴前端工程師逸翾對JavaScript中的異步編程進行了詳細講解。JavaScript的特點就是單線程,本文首先對單線程異步的原理進行了解讀,接著著重分析了JavaScript異步解決方案,詳述了Callback、Promise、Generator、Async/Await的特性和使用原理。

[[229179]]

以下是精彩視頻內容整理:

單線程異步

JavaScript語言的一大特點就是單線程,在某個特定的時刻只有特定的代碼能夠被執行,并阻塞其它的代碼,也就是說,同一個時間只能做一件事。

常用的異步操作最主要有網絡請求,請求會有響應時間,在響應結果回來之前要處理其它事情;IO操作,比如讀取某個文件,在此過程中做其它事情;定時函數。

異步是由瀏覽器的兩個或以上常駐線程共同完成,列如異步請求:JS執行線程發起異步請求,瀏覽器開一條新的http請求來執行請求,當監視到請求已完成,它會把函數插入到JS執行隊列的尾部等待處理。 

通過如圖所示定時函數實例,可以看出異步處理過程。先是打印一個1,然后執行setTimeout函數,約定在0秒后再打印一個2,然后打印一個3,執行結果為先打印1,再打印3,***再打印2,說明整個過程已經發生異步過程。

Javascript有一個主要的執行主線程,但是setTimeout、IO操作、網絡異步請求等都會有一個回調函數,這些操作都是通過瀏覽器API實現的,當定時器時間到了或者請求結果回來時,會將回調函數push到一個javascript任務隊列中,當javascript主線程任務執行完畢后,才會從任務隊列中繼續拿等待代碼再執行。具體流程總結如下:

所有同步任務都在主線程上執行,形成一個執行棧(execution context stack)。

主線程之外,還存在一個"任務隊列"(task queue)。只要異步任務有了運行結果,就在"任務隊列"之中放置一個事件。

一旦"執行棧"中的所有同步任務執行完畢,系統就會讀取"任務隊列",看看里面有哪些事件。那些對應的異步任務,于是結束等待狀態,進入執行棧,開始執行。

主線程不斷重復上面的第三步。

異步解決方案

了解了Javascript單線程與異步關系,如何書寫日常工作中的工程代碼呢?怎樣能在異步請求結束后執行特定方法?目前,javascript異步編程經歷了幾個階段,且在不斷演進。

Callback

最開始是回調函數,當事件完成后執行回調函數,相當于完成異步操作。我們可以像使用變量一樣使用函數,作為另一個函數的參數,在另一個函數中作為返回結果,在另一個函數中調用它。當我們作為參數傳遞一個回調函數給另一個函數時,我們只傳遞了這個函數的定義,并沒有在參數中執行它。當函數擁有了在參數中定義的回調函數后,它可以在任何時候調用(也就是回調)它。

我們在工作中最長接觸的就是發送Ajax異步請求,在***個請求發送完后,用它的參數處理第二個請求,再用第二個請求的參數請求第三個,三層嵌套代碼如圖所示。

如圖所示為mongoDB在node.js中的實例,嵌套了六層。當多個異步事務多級依賴時,回調函數會形成多級的嵌套,代碼變成金字塔型結構。雖然能解決異步問題,但這使得代碼得看難懂,更使得調試、重構的過程充滿風險。

Promise

Promise比傳統解決方案更加合理和強大,是更加好的異步解決方案,promise對象有以下四個特點:

  1. promise 可能有三種狀態:等待(pending)、已完成(resolved)、已拒絕(rejected)。
  2. promise 的狀態只可能從“等待”轉到“完成”態或者“拒絕”態,不能逆向轉換,同時“完成”態和“拒絕”態不能相互轉換。
  3. promise對象必須實現then方法,而且then必須返回一個promise ,同一個 promise 的then可以調用多次(鏈式),并且回調的執行順序跟它們被定義時的順序一致。
  4. then方法接受兩個參數,***個參數是成功時的回調,在 promise 由“等待”態轉換到“完成”態時調用,另一個是失敗時的回調,在 promise 由“等待”態轉換到“拒絕”態時調用

如圖所示,左側創建promise對象,隔2000秒后執行,***返回promise對象。Promise有立即執行性,當創建完對象后,在已完成或已拒絕之前代碼都會執行一遍。右側為打印結果,可以看到創建promise對象被打印出來,并成功生成promise對象,當執行then時,此時已經返回成功狀態,所以一直執行成功的回調函數。

那么,promise如何解決異步問題的呢?又有哪些特點呢?具體如下:

代碼看起來更加符合邏輯、可讀性更強。

Promise并沒有改變JS異步執行的本質,從寫法上甚至還能看到一點點callback的影子。

如圖所示為鏈式調用方式,***個請求成功后,就去執行下一個,如果任何一個請求未成功,直接catch掉error,并打印出來。

Generator

我們希望以同步方式寫異步代碼,可以使邏輯更加清晰,代碼量減少更多。為了實現這種目標,我們又演進出generator解決方案。

Generator函數很特殊,理解起來比promise和callback更加難,從語法上將,generator具備以下特質:

  1. 定義Generator時,需要使用function*。
  2. 使用時生成一個Generator對象。
  3. 執行.next()激活暫停狀態,開始執行內部代碼,直到遇到yield,返回此時執行的結果,并記住此時執行的上下文,暫停。
  4. 再次執行.next()時重復第三步。

如圖所示,首先定義了test=add(5),函數并沒有執行,只是生成了一個generator對象,函數屬于暫停狀態,只有當執行.next()時,才會激活暫停狀態,開始執行內部代碼,直到遇到***個yield才會返回執行結果,并記住上下文,暫停,交出控制權。再次執行.next()時,找到第二個yield,再次記住上下文,暫停,交出控制權,依此重復。

如圖所示,封裝一個異步任務,定義一個generator對象,執行請求后交出控制權,通過promise判斷是否要繼續執行。在異步事件發生后,首先將控制權交給別人,讓程序執行其它代碼,當異步事件完成后,將控制權搶回來,繼續執行其它操作。Generator需要一個自動執行器配合使用,實現正常思維下的異步處理,有了自動執行器,異步請求可以用同步的方式寫異步代碼,直接將請求全部寫在一起。

通過進一步的演進,async和await函數應運而生。它們的個性特征如下:

  1. async 表示這是一個async函數,而await只能在這個函數里面使用。
  2. await 表示在這里等待await后面的操作執行完畢,再執行下一句代碼。
  3. await 后面緊跟著的***是一個耗時的操作或者是一個異步操作。
  4. await后面必須是一個Promise對象,如果不是會被轉化為一個已完成狀態的Promise

Async與generator的寫法類似,本質上是generator的語法糖。其內置執行器,具備更好的語義,更廣的適用性。并且返回值是Promise。  

責任編輯:武曉燕 來源: 云棲社區
相關推薦

2021-06-18 10:45:29

Java內存泄漏C++

2025-05-16 09:34:10

2009-06-24 14:10:22

2018-04-03 05:19:36

網速寬帶Wifi

2021-06-28 08:10:59

JavaScript異步編程

2018-03-19 14:43:28

2017-10-24 14:57:58

AI人工智能機器學習

2021-10-06 16:21:32

類型對象Typescript

2023-12-11 21:59:01

時序分析深度學習自回歸模型

2013-05-06 09:30:17

互聯網創業

2021-12-24 10:01:55

勒索團伙攻擊勒索軟件

2017-08-28 16:40:07

Region切分觸發策略

2017-12-08 10:42:49

HBase切分細節

2022-03-02 10:36:37

Linux性能優化

2019-12-04 07:57:22

6G5G網絡

2019-07-21 08:10:21

技術研發優化

2015-10-12 15:50:40

2018-11-28 10:39:01

5G網絡運營商

2017-02-24 12:29:20

Android Thi開發板硬件

2020-03-18 18:20:19

區塊鏈數字貨幣比特幣
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品久久久久久52avav | 欧美激情欧美激情在线五月 | 成人无遮挡毛片免费看 | 狠狠操在线 | 国精日本亚洲欧州国产中文久久 | 精产嫩模国品一二三区 | 欧美日韩国产在线 | 国产日韩欧美 | 黄久久久 | 五月激情婷婷在线 | 亚洲精品中文字幕在线 | 免费性视频 | 久久久青草婷婷精品综合日韩 | 精品国产三级 | 精品久久久久国产 | 精品一二区 | 成人视屏在线观看 | 精品国产黄a∨片高清在线 www.一级片 国产欧美日韩综合精品一区二区 | 欧美日韩综合精品 | 羞羞视频免费观看 | 日本精品一区二区在线观看 | 欧美精品综合在线 | 四虎永久在线精品免费一区二 | 精品视频一区二区三区 | 久久久精品在线 | 国产精品自产av一区二区三区 | 91原创视频在线观看 | 国产精品一码二码三码在线 | 人人干人人看 | www.天堂av.com | 精品国产伦一区二区三区观看方式 | 成人三级网址 | 欧美一区二区三区高清视频 | 人人草人人干 | 一区二区免费视频 | 毛片区| 亚洲精品视 | 久久久久久久国产精品视频 | 在线看av网址 | 操操日 | 在线高清免费观看视频 |