JS中的同步與異步

首先火本,js是單線程的钙畔,這一點(diǎn)毋庸置疑。

同步異步的概念:
同步:大家按照順序揍魂,你運(yùn)行完我運(yùn)行现斋,不存在你我同時(shí)運(yùn)行的情況庄蹋;優(yōu)點(diǎn)是實(shí)現(xiàn)起來(lái)比較簡(jiǎn)單遂鹊,執(zhí)行環(huán)境相對(duì)單純秉扑;壞處是一旦出現(xiàn)耗時(shí)操作就會(huì)導(dǎo)致整個(gè)程序癱瘓舟陆,停止運(yùn)行;
異步:大家齊頭并進(jìn)踱承,一起運(yùn)行茎活,也就是明面上的“多線程”载荔;

既然異步就約等于多線程,那js這樣一個(gè)單線程語(yǔ)言中工扎,怎么會(huì)存在異步呢定庵?其實(shí)實(shí)際上js確實(shí)不存在真正意義上的“異步”,而是使用 events loop 來(lái)實(shí)現(xiàn)類似異步的效果。events loop 實(shí)際上就是在js在主要代碼(也就是在html中所有定義的script標(biāo)簽)運(yùn)行完后蓝仲,會(huì)開啟的一個(gè)循環(huán)袱结,主要用于監(jiān)聽 HTML 事件和執(zhí)行異步操作溢吻。所以實(shí)際上js就是單線程的促王,包括setTimeout蝇狼,setIntervalXMLHttpRequest都是如此的操作:將需要執(zhí)行的耗時(shí)操作放入循環(huán)中颤专,并在恰當(dāng)實(shí)際執(zhí)行回調(diào)函數(shù)血公。

我們可以用以下代碼來(lái)測(cè)試js一定是單線程:

setTImeout(function(){
    alert("我是一個(gè)彈窗");
},1000);
while(true){
    //不會(huì)結(jié)束的死循環(huán)
}

js有多種方法來(lái)實(shí)現(xiàn)偽異步,比如:回調(diào)函數(shù)垦写,事件監(jiān)聽梯投,發(fā)布訂閱分蓖,Promises對(duì)象么鹤。
回調(diào)函數(shù)就是上述的setTimeout蒸甜,setInterval窍荧,XMLHttpRequest所使用的方法蕊退,傳入一個(gè)函數(shù),并在耗時(shí)操作完成時(shí)執(zhí)行茉贡。
事件監(jiān)聽就是設(shè)定幾個(gè)事件腔丧,為其設(shè)置監(jiān)聽事件愉粤,當(dāng)某個(gè)事件發(fā)生時(shí),執(zhí)行對(duì)應(yīng)的函數(shù)影暴。
發(fā)布訂閱這個(gè)模式與安卓中的廣播類似型宙,可以通過(guò)一個(gè)“平臺(tái)”來(lái)“發(fā)布”某些信息妆兑,之后會(huì)將這個(gè)調(diào)用所有“訂閱”這個(gè)信息的函數(shù),與事件監(jiān)聽很像腺逛,但是可以通過(guò)從消息中心(其實(shí)就是)查看來(lái)更好的監(jiān)控程序屉来。
Promises函數(shù),每一個(gè)異步任務(wù)返回一個(gè)Promise對(duì)象慨绳,該對(duì)象有一個(gè)then方法脐雪,允許指定回調(diào)函數(shù),會(huì)在上一個(gè)世界結(jié)束后調(diào)用脂信。(詳細(xì)可以查看菜鳥教程等)
其實(shí)看完你會(huì)發(fā)現(xiàn)狰闪,所有在js中的“異步”操作,都是耗時(shí)操作加入事件循環(huán)丽声,并在特定時(shí)機(jī)執(zhí)行一個(gè)函數(shù)的模式恒序。
原文鏈接

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子崭参,更是在濱河造成了極大的恐慌何暮,老刑警劉巖海洼,帶你破解...
    沈念sama閱讀 216,744評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件域帐,死亡現(xiàn)場(chǎng)離奇詭異肖揣,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)陋率,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,505評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)菩浙,“玉大人,你說(shuō)我怎么就攤上這事先嬉∫呗” “怎么了衅胀?”我有些...
    開封第一講書人閱讀 163,105評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)茁影。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么呼盆? 我笑而不...
    開封第一講書人閱讀 58,242評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮腿时,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘徽鼎。我一直安慰自己否淤,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,269評(píng)論 6 389
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著侠讯,像睡著了一般厢漩。 火紅的嫁衣襯著肌膚如雪宵膨。 梳的紋絲不亂的頭發(fā)上辟躏,一...
    開封第一講書人閱讀 51,215評(píng)論 1 299
  • 那天裹匙,我揣著相機(jī)與錄音籽御,去河邊找鬼技掏。 笑死哑梳,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的弧哎。 我是一名探鬼主播撤嫩,決...
    沈念sama閱讀 40,096評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼寻拂,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼瞄沙!你這毒婦竟也來(lái)了申尼?” 一聲冷哼從身側(cè)響起师幕,我...
    開封第一講書人閱讀 38,939評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎蒙挑,沒(méi)想到半個(gè)月后矾利,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體舶斧,經(jīng)...
    沈念sama閱讀 45,354評(píng)論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,573評(píng)論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了嗜闻。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,745評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖束倍,靈堂內(nèi)的尸體忽然破棺而出慌盯,到底是詐尸還是另有隱情格嘁,我是刑警寧澤,帶...
    沈念sama閱讀 35,448評(píng)論 5 344
  • 正文 年R本政府宣布,位于F島的核電站殃恒,受9級(jí)特大地震影響离唐,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜嵌戈,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,048評(píng)論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望惰拱。 院中可真熱鬧偿短,春花似錦、人聲如沸勾怒。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,683評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至柠掂,卻和暖如春涯贞,著一層夾襖步出監(jiān)牢的瞬間宋渔,已是汗流浹背孝治。 一陣腳步聲響...
    開封第一講書人閱讀 32,838評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留费什,地道東北人鸳址。 一個(gè)月前我還...
    沈念sama閱讀 47,776評(píng)論 2 369
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像巡球,于是被迫代替她去往敵國(guó)和親险胰。 傳聞我的和親對(duì)象是個(gè)殘疾皇子起便,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,652評(píng)論 2 354

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

  • 前言 在平日的編碼中,你能列出你常用的異步編碼?怎么理解同步與異步? 如果僅僅停留在文字上的理解,個(gè)人覺(jué)得有口無(wú)心...
    itclanCoder閱讀 482評(píng)論 0 1
  • 1.個(gè)人覺(jué)得,js中陋守,最基礎(chǔ)的異步是setTimeout和setInterval函數(shù),很常見中燥,但是很少人有人知道其...
    神秘者007閱讀 523評(píng)論 0 0
  • 你應(yīng)該知道,javascript語(yǔ)言是一門“單線程”的語(yǔ)言咱扣,不像java語(yǔ)言闹伪,類繼承Thread再來(lái)個(gè)thread...
    別人家的xiao孩閱讀 1,327評(píng)論 2 34
  • 目錄 1. 在JS中椰憋,什么是同步異步熏矿? 2. JS中常見的異步代碼 1. 在JS中,什么是同步異步卵渴? 通俗解釋一下...
    臨安linan閱讀 5,087評(píng)論 0 6
  • JS是單線程的同步:指的是等待一件事情完成之后才會(huì)去執(zhí)行下一件事辛藻,JS中大部分都是同步編程吱肌。循環(huán)就是同步的纺蛆,所以在...
    沒(méi)了提心吊膽的稗子閱讀 312評(píng)論 0 0