一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

JAVASCRIPT與單個(gè)線程的工作

汽車(chē)玩家 ? 來(lái)源:今日頭條 ? 作者:魏建民 ? 2020-05-05 22:07 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

事件循環(huán)是用來(lái)理解JavaScript的最重要的方面之一。這篇文章旨在解釋JavaScript如何與單個(gè)線程一起工作的細(xì)節(jié),以及它如何處理異步函數(shù)。

JavaScript代碼運(yùn)行是單線程。一次只執(zhí)行一件事。這實(shí)際上是一個(gè)非常有用的限制,因?yàn)樗?jiǎn)化了很多程序,從而不必?fù)?dān)心并發(fā)問(wèn)題。

您只需要注意編寫(xiě)代碼的方式,避免任何可能阻塞線程的內(nèi)容,如同步調(diào)用或無(wú)限循環(huán)。

通常,在大多數(shù)瀏覽器中,每個(gè)瀏覽器都有一個(gè)事件循環(huán),以使每個(gè)進(jìn)程隔離,并避免web頁(yè)面具有無(wú)限循環(huán)或繁重的處理來(lái)阻塞整個(gè)瀏覽器。

你最需要擔(dān)心的是,您的代碼將在單個(gè)事件循環(huán)上運(yùn)行,并在編寫(xiě)代碼時(shí)考慮到這一點(diǎn),以避免阻塞它。

阻止事件循環(huán)

任何花費(fèi)太長(zhǎng)時(shí)間將控制權(quán)返回給事件循環(huán)的JavaScript代碼都會(huì)阻止頁(yè)面中任何JavaScript代碼的執(zhí)行,甚至阻止UI線程,用戶也無(wú)法點(diǎn)擊,滾動(dòng)頁(yè)面等等。

幾乎所有JavaScript中的I / O操作都是非阻塞的。網(wǎng)絡(luò)請(qǐng)求,Node.js文件系統(tǒng)操作等。阻塞是個(gè)例外,這就是為什么JavaScript基于回調(diào),以及最近的promises和async / await。

調(diào)用堆棧

調(diào)用堆棧是LIFO隊(duì)列(Last In,F(xiàn)irstOut)。事件循環(huán)不斷檢查調(diào)用堆棧以查看是否存在需要運(yùn)行的任何函數(shù)。

在執(zhí)行此操作時(shí),它會(huì)將它找到的任何函數(shù)調(diào)用添加到調(diào)用堆棧并按順序執(zhí)行每個(gè)調(diào)用。

一個(gè)簡(jiǎn)單的事件循環(huán)說(shuō)明:

JAVASCRIPT與單個(gè)線程的工作

當(dāng)此代碼運(yùn)行時(shí),首先f(wàn)oo()調(diào)用。在foo()我們第一次調(diào)用bar(),然后我們調(diào)用baz()。

排隊(duì)功能執(zhí)行

上面的例子運(yùn)行特點(diǎn):JavaScript找到要執(zhí)行的東西,按順序運(yùn)行它們。

讓我們看看如何推遲函數(shù)直到堆棧清除:

用例setTimeout(()=> {}), 0)是調(diào)用一個(gè)函數(shù),但是一旦執(zhí)行了代碼中的每個(gè)其他函數(shù)就執(zhí)行它。

JAVASCRIPT與單個(gè)線程的工作

當(dāng)此代碼運(yùn)行時(shí),首先調(diào)用foo()。在foo()里面我們首先調(diào)用setTimeout,bar作為參數(shù)傳遞,然后我們指示它盡可能快地運(yùn)行,將0作為計(jì)時(shí)器傳遞。然后我們調(diào)用baz()。

消息隊(duì)列

調(diào)用setTimeout()時(shí),瀏覽器或Node.js啟動(dòng)計(jì)時(shí)器。當(dāng)計(jì)時(shí)器到期,我們將0作為超時(shí),回調(diào)函數(shù)立即被放入消息隊(duì)列中。

消息隊(duì)列也是用戶發(fā)起的事件(如單擊事件、鍵盤(pán)事件或獲取響應(yīng))在代碼有機(jī)會(huì)對(duì)其作出響應(yīng)之前排隊(duì)的地方?;蛘呦駉nLoad這樣的DOM事件。

循環(huán)優(yōu)先處理調(diào)用堆棧,它首先處理在調(diào)用堆棧中找到的所有東西,一旦調(diào)用堆棧中沒(méi)有任何東西,它就會(huì)去獲取事件隊(duì)列中的東西。

我們不必等待像setTimeout,fetch或其他東西這樣的函數(shù)來(lái)完成自己的工作,因?yàn)樗鼈兪怯蔀g覽器提供的,并且它們運(yùn)行在自己的線程中。

ES6作業(yè)隊(duì)列

ECMAScript 2015引入了Promises使用的作業(yè)隊(duì)列概念(也在ES6 / ES2015中引入)。這是一種盡快執(zhí)行異步函數(shù)結(jié)果的方法,而不是放在調(diào)用堆棧的末尾。

在當(dāng)前函數(shù)結(jié)束之前解析的Prom將在當(dāng)前函數(shù)之后立即執(zhí)行。

我覺(jué)得在游樂(lè)園里過(guò)山車(chē)的比喻很好:消息隊(duì)列將你放在隊(duì)列的后面,在所有其他人的后面,你將不得不等待輪到你,而作業(yè)隊(duì)列是快速通票這可以讓你在完成上一個(gè)之后再騎一次。

JAVASCRIPT與單個(gè)線程的工作

這是Promises(和Async / await,它建立在promises上)和普通的舊異步函數(shù)setTimeout()或其他平臺(tái)API 之間的巨大差異。

javascrit的事件循環(huán)是這門(mén)語(yǔ)言中非常重要且基礎(chǔ)的概念。清楚的了解了事件循環(huán)的執(zhí)行順序和每一個(gè)階段的特點(diǎn),可以使我們對(duì)一段異步代碼的執(zhí)行順序有一個(gè)清晰的認(rèn)識(shí),從而減少代碼運(yùn)行的不確定性。合理的使用各種延遲事件的方法,有助于代碼更好的按照其優(yōu)先級(jí)去執(zhí)行。

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Web
    Web
    +關(guān)注

    關(guān)注

    2

    文章

    1287

    瀏覽量

    71351
  • javascript
    +關(guān)注

    關(guān)注

    0

    文章

    525

    瀏覽量

    54780
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    深度剖析 RT-Thread 線程調(diào)度流程

    RT-Thread調(diào)度第一個(gè)線程的主要流程分如下:rtthread_startup:RTT的啟動(dòng)函數(shù),主要負(fù)責(zé)板級(jí)驅(qū)動(dòng),調(diào)度器,系統(tǒng)線程初始化,啟動(dòng)調(diào)度的工作
    的頭像 發(fā)表于 06-25 18:24 ?697次閱讀
    深度剖析 RT-Thread <b class='flag-5'>線程</b>調(diào)度流程

    線程的安全注意事項(xiàng)

    線程安全是指多個(gè)線程同時(shí)訪問(wèn)或修改共享資源時(shí),能夠保證程序的正確性和可靠性。 開(kāi)發(fā)者選擇TaskPool或Worker進(jìn)行多線程開(kāi)發(fā)時(shí),在TaskPool和Worker的工作
    發(fā)表于 06-20 07:49

    RTOS如何在FX3中工作?

    大家好, 我正在使用 FX3 進(jìn)行一個(gè)項(xiàng)目。 我想知道 RTOS 調(diào)度是如何工作的。 我知道調(diào)用“CyU3PKernelEntry();”后 RTOS 就會(huì)開(kāi)始工作。 如果我只注冊(cè)一個(gè)應(yīng)用程序線程。 我的
    發(fā)表于 05-06 13:20

    JavaScript與Rust和WebAssembly集成

    偶然一次機(jī)會(huì),接觸了Rust的代碼。當(dāng)時(shí)想給團(tuán)隊(duì)小伙伴做演示,發(fā)現(xiàn)自己并不能在移動(dòng)端按照文檔生成演示demo。我就想,要是Rust代碼能轉(zhuǎn)化成JavaScript就好了。結(jié)果一搜,還真有。
    的頭像 發(fā)表于 01-24 15:43 ?434次閱讀
    <b class='flag-5'>JavaScript</b>與Rust和WebAssembly集成

    SciChart—高性能的JavaScript圖表和圖形庫(kù)

    使用 SciChart 的 JavaScript 圖表庫(kù)為您的 JS 應(yīng)用程序發(fā)現(xiàn)終極解決方案。 使用 WebGL 創(chuàng)建動(dòng)態(tài)、高速的圖表和圖形,非常適合實(shí)時(shí)處理復(fù)雜的數(shù)據(jù)可視化。使用我們強(qiáng)大而靈活
    的頭像 發(fā)表于 01-22 10:15 ?715次閱讀
    SciChart—高性能的<b class='flag-5'>JavaScript</b>圖表和圖形庫(kù)

    Spire.XLS for JavaScript——多功能JavaScript電子表格庫(kù)(一)

    Spire.XLS for JavaScript 是一款專為開(kāi)發(fā)人員設(shè)計(jì)的 JavaScript Excel 工具庫(kù),支持在任何 JavaScript 環(huán)境下直接創(chuàng)建、讀取、編輯和轉(zhuǎn)換 Excel
    的頭像 發(fā)表于 01-21 09:29 ?500次閱讀
    Spire.XLS for <b class='flag-5'>JavaScript</b>——多功能<b class='flag-5'>JavaScript</b>電子表格庫(kù)(一)

    Deno Land 請(qǐng)?jiān)竸儕Z甲骨文 JavaScript 商標(biāo)所有權(quán)

    去年11月,Deno Land 公司向美國(guó)商標(biāo)和專利局(USPTO)提交了一份請(qǐng)?jiān)笗?shū),要求剝奪甲骨文公司對(duì) JavaScript 商標(biāo)的所有權(quán),并指控甲骨文存在欺詐行為。 Deno Land 公司
    的頭像 發(fā)表于 01-15 15:37 ?392次閱讀

    javascript:void(0) 是否影響SEO優(yōu)化

    使用 javascript:void(0) 確實(shí)可能對(duì)SEO優(yōu)化產(chǎn)生負(fù)面影響 。以下是關(guān)于 javascript:void(0) 對(duì)SEO影響的具體分析: 搜索引擎爬蟲(chóng)的理解問(wèn)題 搜索引擎爬蟲(chóng)(如
    的頭像 發(fā)表于 12-31 16:08 ?552次閱讀

    javascript:void(0) 的作用是什么

    javascript:void(0) 在 HTML 和 JavaScript 中是一個(gè)常見(jiàn)的表達(dá)式,主要用來(lái)創(chuàng)建一個(gè)無(wú)操作的鏈接(通常是 標(biāo)簽)或者阻止默認(rèn)事件處理。具體來(lái)說(shuō),它的作用有以下幾點(diǎn)
    的頭像 發(fā)表于 12-31 15:55 ?2374次閱讀

    socket 多線程編程實(shí)現(xiàn)方法

    在現(xiàn)代網(wǎng)絡(luò)編程中,多線程技術(shù)被廣泛應(yīng)用于提高服務(wù)器的并發(fā)處理能力。Socket編程是網(wǎng)絡(luò)通信的基礎(chǔ),而將多線程技術(shù)應(yīng)用于Socket編程,可以顯著提升服務(wù)器的性能。 多線程編程的基本概念 多
    的頭像 發(fā)表于 11-12 14:16 ?997次閱讀

    摩爾線程完成股改,籌備上市

    近日,摩爾線程智能科技(北京)股份有限公司(簡(jiǎn)稱“摩爾線程”)宣布已完成股改,并正積極籌備上市。據(jù)國(guó)家企業(yè)信用信息公示系統(tǒng)最新查詢結(jié)果顯示,摩爾線程的市場(chǎng)主體類型在10月28日已從其他有限責(zé)任公司
    的頭像 發(fā)表于 11-12 14:15 ?1166次閱讀

    摩爾線程與超圖軟件完成產(chǎn)品兼容認(rèn)證

    。 據(jù)悉,為了確保產(chǎn)品間的兼容性,摩爾線程與超圖軟件進(jìn)行了嚴(yán)格的測(cè)試工作。經(jīng)過(guò)雙方的努力,適配調(diào)優(yōu)后的軟件在摩爾線程GPU上展現(xiàn)出了卓越的性能表現(xiàn)。測(cè)試結(jié)果顯示,軟件在摩爾線程GPU上
    的頭像 發(fā)表于 10-24 10:25 ?964次閱讀

    Python中多線程和多進(jìn)程的區(qū)別

    Python作為一種高級(jí)編程語(yǔ)言,提供了多種并發(fā)編程的方式,其中多線程與多進(jìn)程是最常見(jiàn)的兩種方式之一。在本文中,我們將探討Python中多線程與多進(jìn)程的概念、區(qū)別以及如何使用線程池與進(jìn)程池來(lái)提高并發(fā)執(zhí)行效率。
    的頭像 發(fā)表于 10-23 11:48 ?1007次閱讀
    Python中多<b class='flag-5'>線程</b>和多進(jìn)程的區(qū)別

    CPU線程和程序線程的區(qū)別

    CPU的線程與程序的線程在概念、作用、實(shí)現(xiàn)方式以及性能影響等方面存在顯著差異。以下是對(duì)兩者區(qū)別的詳細(xì)闡述,旨在深入探討這一技術(shù)話題。
    的頭像 發(fā)表于 09-02 11:18 ?2115次閱讀

    一文掌握Python多線程

    使用線程可以把占據(jù)長(zhǎng)時(shí)間的程序中的任務(wù)放到后臺(tái)去處理。
    的頭像 發(fā)表于 08-05 15:46 ?1246次閱讀