首頁  >  文章  >  web前端  >  JavaScript 是同步還是異步,是單執行緒還是多執行緒? JavaScript程式碼是如何執行的?

JavaScript 是同步還是異步,是單執行緒還是多執行緒? JavaScript程式碼是如何執行的?

Mary-Kate Olsen
Mary-Kate Olsen原創
2024-09-25 06:20:32880瀏覽

JavaScript 是一種同步、單執行緒語言,一次只能執行一個指令。僅噹噹前行執行完畢後,才會移至下一行。但是,JavaScript 可以使用事件循環、Promises、Async/Await 和回呼佇列執行非同步操作(JavaScript 預設是同步的)。

JavaScript 程式碼是如何執行的?

JavaScript 中的一切都發生在執行上下文中(將其視為一個大盒子或容器)。整個 JavaScript 程式碼都在此執行上下文中執行。它有兩個元件:記憶體元件(變數環境)和程式碼元件(執行緒)。

  • 記憶體元件: 這是所有變數和函數以鍵值對形式儲存的地方。
  • 程式碼元件:這是執行程式碼的地方(一次一行)。 ”

首先,建立一個全域執行上下文。在此範圍內,每個函數都會建立自己的執行上下文。

在執行任何行程式碼之前,都會為所有變數和函數分配記憶體。

記憶體分配後程式碼是如何執行的?
JavaScript 引擎再次(逐行)運行整個程式並執行程式碼。

我們看下面的範例:

function add(a,b){
   var ans = a+b;
   console.log(ans);
}
var addition = add(6,5);

在這個例子中,首先建立了一個全域執行上下文,它由兩個元件組成:記憶體元件(MC)和程式碼元件(CC)。

Is JavaScript synchronous or asynchronous, and is it single-threaded or multi-threaded? How is JavaScript code executed?

對於函數來說,整個函數程式碼都儲存在記憶體中。對於變量,最初儲存一個特殊的值,未定義。

Is JavaScript synchronous or asynchronous, and is it single-threaded or multi-threaded? How is JavaScript code executed?

呼叫函數時,會建立另一個執行上下文。在記憶體元件中,儲存參數值(a = 6,b = 5),而像 ans 這樣的變數最初保留未定義的值。在程式碼元件中,記憶體組件中的值用於執行操作 (a + b = 6 + 5 = 11)。然後將結果列印到控制台。

我希望這個解釋能夠澄清這個概念。如果有任何問題或更正,歡迎在評論區提問。

感謝 Akshay Saini(參考:[(https://youtu.be/iLWTnMzWtj4?si=WWMxDHM-v532vY7F)])

以上是JavaScript 是同步還是異步,是單執行緒還是多執行緒? JavaScript程式碼是如何執行的?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn