這篇文章主要講解了“JavaScript中事件循環(huán)總結(jié)”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“JavaScript中事件循環(huán)總結(jié)”吧!
創(chuàng)新互聯(lián)是一家專業(yè)從事網(wǎng)站建設(shè)、成都網(wǎng)站制作的網(wǎng)絡(luò)公司。作為專業(yè)的建站公司,創(chuàng)新互聯(lián)依托的技術(shù)實力、以及多年的網(wǎng)站運營經(jīng)驗,為您提供專業(yè)的成都網(wǎng)站建設(shè)、成都營銷網(wǎng)站建設(shè)及網(wǎng)站設(shè)計開發(fā)服務(wù)!
js中的事件循環(huán)
因為JavaScript是單線程的,同一事件只能執(zhí)行一種方法,所以會將程序中的方法加入到執(zhí)行棧中按照后進(jìn)先出的順序依次執(zhí)行,當(dāng)遇見異步任務(wù)時不會被阻塞,而是將任務(wù)放入事件隊列中,繼續(xù)執(zhí)行執(zhí)行棧中的同步代碼,等當(dāng)前執(zhí)行棧中的所有任務(wù)都執(zhí)行完畢則查找事件隊列中的任務(wù),并把任務(wù)的回調(diào)函數(shù)放入執(zhí)行棧中,執(zhí)行其中的同步代碼,如此反復(fù)形成的循環(huán)被稱為事件循環(huán)。
node.js
node.js特點
事件驅(qū)動
從上向下執(zhí)行代碼,當(dāng)遇到需要回調(diào)的地方就加入到事件隊列中,主線程運行完就去執(zhí)行事件隊列中的回調(diào)。整個過程不會阻塞新的事件,也不需要維護(hù)已經(jīng)建立的事件
非阻塞io
主線程空閑時,就開始循環(huán)事件隊列,處理事件隊列中的事件,如果該事件不是io任務(wù)就親自處理,如果是io任務(wù),則交給線程池處理并指定回調(diào)函數(shù),然后繼續(xù)循環(huán)隊列中的其他事件,當(dāng)阻塞操作完成后會將結(jié)果和回調(diào)函數(shù)放入隊列中,主線程循環(huán)到時就執(zhí)行該回調(diào)函數(shù)。
node.js優(yōu)缺點
優(yōu)點
高并發(fā):node.js用一個主線程處理所有的請求,然后對io操作進(jìn)行異步處理,避開了創(chuàng)建、銷毀線程以及在線程之間切換所需的開銷和復(fù)雜性
適合io密集型應(yīng)用
缺點:
不適合CPU密集型應(yīng)用:長時間的計算會導(dǎo)致cpu時間片不能釋放,使得后續(xù)io事件無法發(fā)起
不能充分利用多核cpu
可靠性低,一旦代碼某個環(huán)節(jié)崩潰,整個系統(tǒng)都會崩潰
適用場景:
restful api:請求和響應(yīng)只需少量的文本,不需要大量的邏輯處理??梢蕴幚頂?shù)萬條連接,只需請求api組織數(shù)據(jù)并返回即可
大量Ajax請求的場景中
聊天服務(wù):輕量級,高流量,沒有復(fù)雜的計算邏輯
node.js的事件循環(huán)
node事件循環(huán)依靠libuv引擎,v8解釋js代碼后調(diào)用對應(yīng)的node api,這些api由libuv引擎驅(qū)動執(zhí)行對應(yīng)任務(wù),并把不同的事件放入不同的隊列中等待主線程執(zhí)行,因此node的事件循環(huán)存在于libuv引擎中。
libuv引擎:實現(xiàn)了事件循環(huán)、文件操作等,是node.js實現(xiàn)異步的核心
node.js的單線程僅僅指JavaScript運行在單線程中,內(nèi)部可以通過線程池完成io操作
poll(查詢階段)---》check(檢查階段)---》close callback(關(guān)閉事件回調(diào)階段)---》timer(定時器檢測階段)---》io回調(diào)階段---》閑置階段---》輪詢階段
poll階段(輪詢階段):
v8將js代碼解析后傳入libuv引擎中,循環(huán)首先進(jìn)入poll階段。先查看poll隊列是否有事件,有就按先進(jìn)先出順序執(zhí)行回調(diào)。
感謝各位的閱讀,以上就是“JavaScript中事件循環(huán)總結(jié)”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對JavaScript中事件循環(huán)總結(jié)這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!