JS異步編程(一):單線程模型

隨著對JS的深入,異步編程是每個JS程序員都跳不過的話題炮车。不僅在前端開發(fā)有大量的異步事件處理衷笋,NODE更是有出了名的callback hell。為了更好地掌握J(rèn)S異步編程豫领,讓我們從基礎(chǔ)開始看起吧抡柿。

先看一個簡單的例子:

for (var i = 1; i <= 3; i++) {
    setTimeout(function() { console.log(i); }, 0);
}

若是從C、JAVA轉(zhuǎn)來的程序員等恐,第一直覺是setTimeout延時為0洲劣,因此程序應(yīng)該打印1,2课蔬,3囱稽。但是程序執(zhí)行的結(jié)果卻是4,4二跋,4战惊。

再看下面一個列子:

var start = new Date;
setTimeout(function(){
    var end = new Date;
    console.log('Time elapsed:', end - start, 'ms');
}, 500);
while (new Date - start < 1000) {};

SetTimeout設(shè)置了500ms的延遲,而隨后的while則空循環(huán)等待1000ms扎即。直覺的反應(yīng)是console會打印500吞获,但執(zhí)行的結(jié)果卻是出乎意料的約等于1000。

這里充分說明了一個問題:setTimeout沒有調(diào)用另一個線程谚鄙,JS程序的執(zhí)行是基于單線程模型的各拷。于是當(dāng)調(diào)用setTimeout的時候,這個延時事件便會排入事件隊列闷营。而線程繼續(xù)執(zhí)行后續(xù)的代碼烤黍,直到代碼全部執(zhí)行完畢之后才來處理事件隊列中的事件。

處理用戶輸入時也是類似的情況,當(dāng)用戶點擊一個附加了事件處理函數(shù)的對象時速蕊,這個點擊事件就排入事件隊列嫂丙。但該事件并不會被立即處理,而是要等到當(dāng)前代碼全部運行結(jié)束后才會被處理互例。

小結(jié):JS是單線程執(zhí)行的奢入,JS代碼永遠(yuǎn)不會被中斷筝闹,所有的事件都會被排入事件隊列媳叨,直到代碼執(zhí)行完畢后才會處理這些事件。

P.S: webkit的console.log也是異步的关顷,在瀏覽器中執(zhí)行:

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

console并沒有立即打印空對象糊秆,而是等到代碼返回到事件隊列的時候才打印對象,此時打印是對象{foo:bar}议双。

與此相反痘番,NODE中console是同步的,將會立即打印{}平痰。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末汞舱,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子宗雇,更是在濱河造成了極大的恐慌昂芜,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,496評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件赔蒲,死亡現(xiàn)場離奇詭異泌神,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)舞虱,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,187評論 3 385
  • 文/潘曉璐 我一進(jìn)店門欢际,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人矾兜,你說我怎么就攤上這事损趋。” “怎么了椅寺?”我有些...
    開封第一講書人閱讀 157,091評論 0 348
  • 文/不壞的土叔 我叫張陵浑槽,是天一觀的道長。 經(jīng)常有香客問我配并,道長括荡,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,458評論 1 283
  • 正文 為了忘掉前任溉旋,我火速辦了婚禮畸冲,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己邑闲,他們只是感情好算行,可當(dāng)我...
    茶點故事閱讀 65,542評論 6 385
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著苫耸,像睡著了一般州邢。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上褪子,一...
    開封第一講書人閱讀 49,802評論 1 290
  • 那天量淌,我揣著相機(jī)與錄音,去河邊找鬼嫌褪。 笑死呀枢,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的笼痛。 我是一名探鬼主播裙秋,決...
    沈念sama閱讀 38,945評論 3 407
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼缨伊!你這毒婦竟也來了摘刑?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,709評論 0 266
  • 序言:老撾萬榮一對情侶失蹤刻坊,失蹤者是張志新(化名)和其女友劉穎枷恕,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體紧唱,經(jīng)...
    沈念sama閱讀 44,158評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡活尊,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,502評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了漏益。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蛹锰。...
    茶點故事閱讀 38,637評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖绰疤,靈堂內(nèi)的尸體忽然破棺而出铜犬,到底是詐尸還是另有隱情,我是刑警寧澤轻庆,帶...
    沈念sama閱讀 34,300評論 4 329
  • 正文 年R本政府宣布癣猾,位于F島的核電站,受9級特大地震影響余爆,放射性物質(zhì)發(fā)生泄漏纷宇。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,911評論 3 313
  • 文/蒙蒙 一蛾方、第九天 我趴在偏房一處隱蔽的房頂上張望像捶。 院中可真熱鬧上陕,春花似錦、人聲如沸拓春。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,744評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽硼莽。三九已至庶溶,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間懂鸵,已是汗流浹背偏螺。 一陣腳步聲響...
    開封第一講書人閱讀 31,982評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留矾瑰,地道東北人砖茸。 一個月前我還...
    沈念sama閱讀 46,344評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像殴穴,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子货葬,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,500評論 2 348

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