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)])
免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。
Copyright© 2022 湘ICP备2022001581号-3