JS異步編程

1邓深、創(chuàng)造 Node.js樱调,并不是為了人們能在服務(wù)器上運(yùn)行 JavaScript,僅僅是因?yàn)?Ryan Dahl想要一個(gè)建立在某高級語言之上的事件驅(qū)動型服務(wù)器框架。JavaScript碰巧就是適合干這個(gè)的語言毡琉。為什么?因?yàn)镴avaScript語言可以完美地實(shí)現(xiàn)非阻塞式 I/O身冬。

2玄括、WebKit的 console.log 由于表現(xiàn)出異步行為而讓很多開發(fā)者驚詫不已。在Chrome或Safari中银锻,以下這段代碼會在控制臺記錄
{foo:bar} 永品。

var obj = {};
console.log(obj);
obj.foo = 'bar';

3、隊(duì)列

4击纬、回調(diào)

5鼎姐、異步錯(cuò)誤的處理
EventModel/stackTrace.js

function JSONToObject(jsonStr) {
return JSON.parse(jsonStr);
}
var obj = JSONToObject('{');

SyntaxError: Unexpected end of input
at Object.parse (native)
at JSONToObject (/AsyncJS/stackTrace.js:2:15)
at Object.<anonymous> (/AsyncJS/stackTrace.js:4:11)

堆棧軌跡不僅告訴我們哪里拋出了錯(cuò)誤,而且說明了最初出錯(cuò)的地方如果從異步回調(diào)中拋出錯(cuò)誤,會發(fā)生什么事炕桨?讓我們先來做個(gè)測試饭尝。

setTimeout(function A() {
setTimeout(function B() {
setTimeout(function C() {
throw new Error('Something terrible has happened!');
}, 0);
}, 0);
}, 0);

Error: Something terrible has happened!
at Timer.C (/AsyncJS/nestedErrors.js:4:13)
等等,A和 B發(fā)生了什么事献宫?為什么它們沒有出現(xiàn)在堆棧軌跡中钥平?這是因?yàn)檫\(yùn)行 C 的時(shí)候,A和 B并不在內(nèi)存堆棧里姊途。這 3個(gè)函數(shù)都是從事件隊(duì)列直接運(yùn)行的涉瘾。
基于同樣的理由,利用 try/catch 語句塊并不能捕獲從異步回調(diào)中拋出的錯(cuò)誤吭净。

try {
setTimeout(function() {
throw new Error('Catch me if you can!');
}, 0);
} catch (e) {
console.error(e);
}

看到這里的問題了嗎睡汹?這里的 try/catch 語句塊只捕獲 setTimeout函數(shù)自身內(nèi)部發(fā)生的那些錯(cuò)誤。因?yàn)?setTimeout 異步地運(yùn)行其回調(diào)寂殉,所以即使延時(shí)設(shè)置為 0囚巴,回調(diào)拋出的錯(cuò)誤也會直接流向應(yīng)用程序的未捕獲異常處理器總的來說,取用異步回調(diào)的函數(shù)即使包裝上 try/catch 語句塊友扰,也只是無用之舉彤叉。
不過最常見的模式是,針對成敗這兩種情形各規(guī)定一個(gè)單獨(dú)的回調(diào)村怪。始終要記住的是秽浇,只能在回調(diào)內(nèi)部處理源于回調(diào)的異步錯(cuò)誤。
6甚负、多線程性worker
在不損害 DOM響應(yīng)能力的前提下處理復(fù)雜的計(jì)算
? 解碼視頻柬焕。流入的視頻采用 Broadway實(shí)現(xiàn)的 H.264編解碼器
? 采用斯坦福的 JavaScript加密庫加密通信。
? 解析網(wǎng)頁式編輯器中的文本梭域。沒錯(cuò)斑举,就是 Ace編輯器

7、promise和Deferred

Paste_Image.png

通過 ES6 Promise 和 jQuery Deferred 的異同學(xué)習(xí) Promise

8病涨、Async
9富玷、<script> 標(biāo)簽經(jīng)典型和非阻塞型
Require.js/AMD的智能加載

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市既穆,隨后出現(xiàn)的幾起案子赎懦,更是在濱河造成了極大的恐慌,老刑警劉巖幻工,帶你破解...
    沈念sama閱讀 218,284評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件励两,死亡現(xiàn)場離奇詭異,居然都是意外死亡囊颅,警方通過查閱死者的電腦和手機(jī)伐蒋,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評論 3 395
  • 文/潘曉璐 我一進(jìn)店門工三,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人先鱼,你說我怎么就攤上這事俭正。” “怎么了焙畔?”我有些...
    開封第一講書人閱讀 164,614評論 0 354
  • 文/不壞的土叔 我叫張陵掸读,是天一觀的道長。 經(jīng)常有香客問我宏多,道長儿惫,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,671評論 1 293
  • 正文 為了忘掉前任伸但,我火速辦了婚禮肾请,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘更胖。我一直安慰自己铛铁,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,699評論 6 392
  • 文/花漫 我一把揭開白布却妨。 她就那樣靜靜地躺著饵逐,像睡著了一般。 火紅的嫁衣襯著肌膚如雪彪标。 梳的紋絲不亂的頭發(fā)上倍权,一...
    開封第一講書人閱讀 51,562評論 1 305
  • 那天,我揣著相機(jī)與錄音捞烟,去河邊找鬼薄声。 笑死,一個(gè)胖子當(dāng)著我的面吹牛题画,可吹牛的內(nèi)容都是我干的默辨。 我是一名探鬼主播,決...
    沈念sama閱讀 40,309評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼婴程,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了抱婉?” 一聲冷哼從身側(cè)響起档叔,我...
    開封第一講書人閱讀 39,223評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎蒸绩,沒想到半個(gè)月后衙四,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,668評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡患亿,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,859評論 3 336
  • 正文 我和宋清朗相戀三年传蹈,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了押逼。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,981評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡惦界,死狀恐怖挑格,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情沾歪,我是刑警寧澤漂彤,帶...
    沈念sama閱讀 35,705評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站灾搏,受9級特大地震影響挫望,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜狂窑,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,310評論 3 330
  • 文/蒙蒙 一媳板、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧泉哈,春花似錦蛉幸、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至采呐,卻和暖如春若锁,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背斧吐。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評論 1 270
  • 我被黑心中介騙來泰國打工又固, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人煤率。 一個(gè)月前我還...
    沈念sama閱讀 48,146評論 3 370
  • 正文 我出身青樓仰冠,卻偏偏與公主長得像,于是被迫代替她去往敵國和親蝶糯。 傳聞我的和親對象是個(gè)殘疾皇子洋只,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,933評論 2 355

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