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)。
對於函數來說,整個函數程式碼都儲存在記憶體中。對於變量,最初儲存一個特殊的值,未定義。
呼叫函數時,會建立另一個執行上下文。在記憶體元件中,儲存參數值(a = 6,b = 5),而像 ans 這樣的變數最初保留未定義的值。在程式碼元件中,記憶體組件中的值用於執行操作 (a + b = 6 + 5 = 11)。然後將結果列印到控制台。
我希望這個解釋能夠澄清這個概念。如果有任何問題或更正,歡迎在評論區提問。
感謝 Akshay Saini(參考:[(https://youtu.be/iLWTnMzWtj4?si=WWMxDHM-v532vY7F)])
以上是JavaScript 是同步還是異步,是單執行緒還是多執行緒? JavaScript程式碼是如何執行的?的詳細內容。更多資訊請關注PHP中文網其他相關文章!