主頁 > 區塊鏈 > 為什么Javascript的阻塞函式比Python少得多

為什么Javascript的阻塞函式比Python少得多

2021-10-16 16:28:37 區塊鏈

從 Javascript 到 Python,看著asyncio讓我有點困惑。

作為對并發基本概念不熟悉的人,我只是假設對 Javascript 并發有一個膚淺的理解。

async / await在 Javascript 中使用的基本理解

如果我們在async函式內部運行任何行程,以及函式await的回應,我們實際上是在等待函式在Promise.

完全有道理 - 當Promise給定一個值時,我們還可以使用回呼.then()來處理回應。或者,只是await.

無論此處異步性的底層實作是什么(例如,所有行程都在具有事件回圈的單個執行緒上運行),我們如何與之互動是否重要?

現在,我轉向 Python 并開始使用asyncio. 我們有Futures,就像Promises突然之間,我無法使用我的標準庫,例如request.get(...),但我需要在庫中使用非阻塞網路請求,例如aiohttp.

阻塞/非阻塞在這里是什么意思?我認為這意味著事件回圈所在的單執行緒被阻塞,因此我們無法并行處理其他函式。

所以我的兩個問題是:

  • 是什么導致單執行緒被阻塞?例如在requests.get(...)
  • 為什么大多數函式在 Javascript 中是非阻塞的,但在 Python 中不是(即我們不需要特定的庫,例如aiohttp)。

而關于語言什么喜歡Go他們goroutines這是否只是一種情況,因為它是一種從一開始就內置并發性的新語言,不存在阻塞函式的概念。或者在 Go 中它不是單執行緒,所以一切都可以本質上并行化?

謝謝 :)

uj5u.com熱心網友回復:

事件回圈

Javascript 和 python 的異步 io 使用基于事件回圈的并發模型

(注意復數,因為你可以有多個事件回圈來處理不同型別的任務,例如磁盤 io、網路 io、ipc、并行計算等)

事件回圈的一般概念是,你有很多事情要做,所以你把這些事情放在一個佇列中,每隔一段時間(比如每納秒),事件回圈從佇列中選擇一個事件,然后運行它一小會兒(可能是一毫秒左右),如果它沒有完成,要么將它推回佇列,要么等待直到它把控制權交還給事件回圈。


現在回答你的一些問題:

阻塞/非阻塞在這里是什么意思?我認為這意味著事件回圈所在的單執行緒被阻塞,因此我們無法并行處理其他函式。

阻塞事件回圈

阻塞事件回圈發生在事件回圈正在運行一個任務,并且任務沒有完成或將控制權交還給事件回圈,時間超過事件回圈安排它運行的時間。

在 python 的請求庫的情況下,他們使用同步 http 庫,它不考慮事件回圈;因此,在回圈中運行這樣的任務會使其他耐心等待輪到它們運行的??任務餓死,直到請求完成。

為什么大多數函式在 Javascript 中是非阻塞的,但在 Python 中不是(即我們不需要特定的庫,例如aiohttp)。

JS

Javascript 中的一切都可以阻止事件回圈。不阻塞事件回圈的唯一方法是通過setTimeout大量使用回呼但是,如果不小心,即使這些回呼運行時間過長,也可能會阻塞事件回圈,而不會通過另一個setTimeout呼叫將控制權交還給事件回圈

(如果您從未使用過setTimeout,但在 JS 中使用過 promise 和異步網路請求,那么您可能正在使用一個可以使用的庫。瀏覽器中使用的大多數流行網路庫(ajax、axios、fetch 等) ),基于流行的XMLHttpRequestAPI,提供異步網路 IO。)

Python

在 python 中,情況略有不同:在 asyncio 之前,沒有“事件回圈”這樣的東西。在 python 解釋器繼續下一步之前,一切都必須運行完成。這是使 python 非常容易學習的部分原因(我敢說,創建......)。這樣做的原因是以 python GIL的形式出現的,簡單來說,它對任何 python 程式強制執行單一的執行順序。我鼓勵您單擊該鏈接,并閱讀 GIL 存在的原因。

而關于語言什么喜歡Go他們goroutines

注意:我不是圍棋程式員,但我讀過一些東西

Go 有什么不同?

The only difference between the way go handles goroutines and how python asyncio/js do their event loops, is that go makes more use of os threads to ensure that threads are scheduled fairly and make full use of the machine they run in.

While js callbacks/asyncio tasks will often run in the same thread as the event loop, goroutines are able to run in seperate OS threads and over multiple cores, thus giving them higher availability and higher parallelism. (In that case, we could almost consider goroutines to be closer to OS threads in terms of how much time they actually get to run, as compared to green threads which are bound by the amount of time the event loop's thread runs.)

轉載請註明出處,本文鏈接:https://www.uj5u.com/qukuanlian/318759.html

標籤:javascript Python 多线程 异步等待 蟒蛇异步

上一篇:如何從回復id(Python)中獲取執行緒/對話?

下一篇:使用多處理python將元素添加到串列

標籤雲
其他(123570) Java(13369) Python(12731) C(7545) 區塊鏈(7372) JavaScript(7059) 基礎類(6313) AI(6244) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4120) MySQL(4012) Linux(3394) C語言(3288) C++語言(3117) Java相關(2746) 疑難問題(2699) 單片機工控(2479) Web開發(1951) 網絡通信(1793) 數據庫相關(1767) VB基礎類(1755) PHP(1727) 開發(1646) 系統維護與使用區(1617) .NETCore(1586) 基礎和管理(1579) JavaEE(1566) C++(1527) 專題技術討論區(1515) Windows客戶端使用(1484) HtmlCss(1466) ASP.NET(1428) Unity3D(1354) VCL組件開發及應用(1353) HTML(CSS)(1220) 其他技術討論專區(1200) WindowsServer(1192) .NET技术(1165) 交換及路由技術(1149) 語言基礎算法系統設計(1133) WindowsSDKAPI(1124) 界面(1088) JavaSE(1075) Qt(1074) VBA(1048) 新手樂園(1016) 其他開發語言(947) Go(907) HTML5(901) 新技術前沿(898) 硬件設計(872) 區塊鏈技術(860) 網絡編程(857) 非技術版(846) 一般軟件使用(839) 網絡協議與配置(835) Eclipse(790) Spark(750) 下載資源懸賞專區(743)

熱門瀏覽
  • JAVA使用 web3j 進行token轉賬

    最近新學習了下區塊鏈這方面的知識,所學不多,給大家分享下。 # 1. 關于web3j web3j是一個高度模塊化,反應性,型別安全的Java和Android庫,用于與智能合約配合并與以太坊網路上的客戶端(節點)集成。 # 2. 準備作業 jdk版本1.8 引入maven <dependency> < ......

    uj5u.com 2020-09-10 03:03:06 more
  • 以太坊智能合約開發框架Truffle

    前言 部署智能合約有多種方式,命令列的瀏覽器的渠道都有,但往往跟我們程式員的風格不太相符,因為我們習慣了在IDE里寫了代碼然后打包運行看效果。 雖然現在IDE中已經存在了Solidity插件,可以撰寫智能合約,但是部署智能合約卻要另走他路,沒辦法進行一個快捷的部署與測驗。 如果團隊管理的區塊節點多、 ......

    uj5u.com 2020-09-10 03:03:12 more
  • 谷歌二次驗證碼成為區塊鏈專用安全碼,你怎么看?

    前言 谷歌身份驗證器,前些年大家都比較陌生,但隨著國內互聯網安全的加強,它越來越多地出現在大家的視野中。 比較廣泛接觸的人群是國際3A游戲愛好者,游戲盜號現象嚴重+國外賬號安全應用廣泛,這類游戲一般都會要求用戶系結名為“兩步驗證”、“雙重驗證”等,平臺一般都推薦用谷歌身份驗證器。 后來區塊鏈業務風靡 ......

    uj5u.com 2020-09-10 03:03:17 more
  • 密碼學DAY1

    目錄 ##1.1 密碼學基本概念 密碼在我們的生活中有著重要的作用,那么密碼究竟來自何方,為何會產生呢? 密碼學是網路安全、資訊安全、區塊鏈等產品的基礎,常見的非對稱加密、對稱加密、散列函式等,都屬于密碼學范疇。 密碼學有數千年的歷史,從最開始的替換法到如今的非對稱加密演算法,經歷了古典密碼學,近代密 ......

    uj5u.com 2020-09-10 03:03:50 more
  • 密碼學DAY1_02

    目錄 ##1.1 ASCII編碼 ASCII(American Standard Code for Information Interchange,美國資訊交換標準代碼)是基于拉丁字母的一套電腦編碼系統,主要用于顯示現代英語和其他西歐語言。它是現今最通用的單位元組編碼系統,并等同于國際標準ISO/IE ......

    uj5u.com 2020-09-10 03:04:50 more
  • 密碼學DAY2

    ##1.1 加密模式 加密模式:https://docs.oracle.com/javase/8/docs/api/javax/crypto/Cipher.html ECB ECB : Electronic codebook, 電子密碼本. 需要加密的訊息按照塊密碼的塊大小被分為數個塊,并對每個塊進 ......

    uj5u.com 2020-09-10 03:05:42 more
  • NTP時鐘服務器的特點(京準電子)

    NTP時鐘服務器的特點(京準電子) NTP時鐘服務器的特點(京準電子) 京準電子官V——ahjzsz 首先對時間同步進行了背景介紹,然后討論了不同的時間同步網路技術,最后指出了建立全球或區域時間同步網存在的問題。 一、概 述 在通信領域,“同步”概念是指頻率的同步,即網路各個節點的時鐘頻率和相位同步 ......

    uj5u.com 2020-09-10 03:05:47 more
  • 標準化考場時鐘同步系統推進智能化校園建設

    標準化考場時鐘同步系統推進智能化校園建設 標準化考場時鐘同步系統推進智能化校園建設 安徽京準電子科技官微——ahjzsz 一、背景概述隨著教育事業的快速發展,學校建設如雨后春筍,隨之而來的學校教育、管理、安全方面的問題成了學校管理人員面臨的最大的挑戰,這些問題同時也是學生家長所擔心的。為了讓學生有更 ......

    uj5u.com 2020-09-10 03:05:51 more
  • 位元幣入門

    引言 位元幣基本結構 位元幣基礎知識 1)哈希演算法 2)非對稱加密技術 3)數字簽名 4)MerkleTree 5)哪有位元幣,有的是UTXO 6)位元幣挖礦與共識 7)區塊驗證(共識) 總結 引言 上一篇我們已經知道了什么是區塊鏈,此篇說一下區塊鏈的第一個應用——位元幣。其實先有位元幣,后有的區塊 ......

    uj5u.com 2020-09-10 03:06:15 more
  • 北斗對時服務器(北斗對時設備)電力系統應用

    北斗對時服務器(北斗對時設備)電力系統應用 北斗對時服務器(北斗對時設備)電力系統應用 京準電子科技官微(ahjzsz) 中國北斗衛星導航系統(英文名稱:BeiDou Navigation Satellite System,簡稱BDS),因為是目前世界范圍內唯一可以大面積提供免費定位服務的系統,所以 ......

    uj5u.com 2020-09-10 03:06:20 more
最新发布
  • 具有多個成員函式的實體的執行緒安全鎖定

    我有一個被多個執行緒使用的結構實體。每個執行緒都包含未知數量的函式呼叫,這些函式呼叫會改變結構體成員變數。我有一個專用函式,它嘗試為當前執行緒“保留”結構實體,并且我...

    uj5u.com 2021-10-16 16:32:53 more
  • 如何避免沒有謂詞的虛假喚醒?

    我有一個執行緒可以叫它 t1,它會在 x 秒后定期發送一些東西。這個“x 秒部分”可以從其他執行緒 (t2)更改。我應該能夠從執行緒 t1 執行以下操作。等待“x 秒”然后發送一些...

    uj5u.com 2021-10-16 16:32:27 more
  • 多次啟動執行緒

    我想使用執行緒將檔案上傳到服務器。只要ThreadState是Unstarted,我就可以用它ThreadName.Start()來啟動執行緒。代碼完成后ThreadState會得到Stopped。我怎樣才能再次啟動該...

    uj5u.com 2021-10-16 16:31:50 more
  • 多執行緒中的Boost:asio和async

    我需要呼叫作為遠程服務器請求的方法。之后我想等待答案,并且等待不會被其他異步函式/物件(例如計時器)阻止。方法 got_response(...) 告訴用戶他從遠程服務器得到了一個答案,方...

    uj5u.com 2021-10-16 16:31:18 more
  • 為什么從并發佇列異步呼叫`DispatchQueue.main.sync`成功但同步

    在這里,我創建了具有 .background 優先級的并發佇列:let background = DispatchQueue(label: "backgroundQueue", qos: .background,...

    uj5u.com 2021-10-16 16:30:33 more
  • 如果執行緒生成速度過快,Ruby作業分配會失敗

    前幾天我遇到了一個問題,我花了 2 個小時在錯誤的地方尋找答案。在此程序中,我將代碼精簡為以下版本。只要我sleep(0.1)在回圈中創建執行緒,這里的執行緒就可以作業。如果省略...

    uj5u.com 2021-10-16 16:29:58 more
  • 使用多處理python將元素添加到串列

    我定義了一個接受單個整數輸入并回傳輸出整數的函式。def get_output(n): output = # process the integer return output現在我已經定義了一個必須使用上面定義的函式進...

    uj5u.com 2021-10-16 16:29:29 more
  • 為什么Javascript的阻塞函式比Python少得多

    從 Javascript 到 Python,看著asyncio讓我有點困惑。作為對并發基本概念不熟悉的人,我只是假設對 Javascript 并發有一個膚淺的理解。async / await在 Javascript 中使用的基...

    uj5u.com 2021-10-16 16:28:37 more
  • 如何從回復id(Python)中獲取執行緒/對話?

    我是 python 的相對新手,我正在嘗試從具有 ID 串列的資料幀重建對話/執行緒。我目前有一個推文/reddit帖子的pandas資料框,其格式大致如下:ID文本parent_id回復編號1呸呸_ 郵政...

    uj5u.com 2021-10-16 16:28:09 more
  • 將函式傳遞給多處理池中的地圖或星圖

    我一直試圖在我的機器上的 Jupyter 上測驗這段簡單的代碼,并且該單元無限期地運行而不輸出任何內容。是否有某種錯誤或什么?我為熊貓行程使用了??完全相同的代碼,pool.map并且...

    uj5u.com 2021-10-16 16:27:40 more