JS基礎之執行上下文

JS基礎之執行上下文

  • 執行上下文
    • 順序執行
    • 可執行代碼
    • 執行上下文棧
    • 回顧上文

執行上下文

順序執行

寫個JavaScript的開發者都會有個直觀的印象,那就是順序執行:

var foo = function(){console.log('foo1')
}
foo(); //foo1
var foo = function(){console.log('foo2');
}
foo();//foo2

那這段呢?

function foo(){console.log('foo1');
}
foo(); // foo2
function foo(){console.log('foo2');
}
foo(); //foo2

打印的結果卻是兩個foo2
這是因為JavaScript引擎并非一行一行的分析和執行程序,而是一段一段的分析執行。當執行一段代碼的時候,會進行一個“準備工作”,那這個“一段一段”中的“段”究竟是怎么劃分的呢?
到底JavaScript引擎遇到一段怎樣的代碼時,才會做“準備工作”呢?

console.log(add2(1,2));//輸出3
function add2(a,b){return a+b;
}
console.log(add1(1,1));//報錯:add1 is not a function
var add1 = function(a,b){return a+b;
}
//用函數語句創建的函數add2,函數名稱和函數體均被提前,在聲明他之前就使用它。
//但是使用var表達式定義函數add1,只有變量聲明提前了,變量初始化代碼仍然在原來的位置,沒有辦法提前執行。

可執行代碼

這就要說到JavaScript的可執行代碼(executable code)的類型有哪些了?
其實很簡單,就三種,全局代碼、函數代碼、eval代碼
舉個例子,當執行到一個函數的時候,就會進行準備工作,這里的“準備工作”,讓我們用更專業的說法,就叫做“執行上下文(execution context)”。

執行上下文棧

JavaScript引擎創建了執行上下文棧(Execution Context stack, ECS)來管理執行上下文,為了模擬執行上下文棧的行為,讓我們定義執行上下文棧是一個數組:

ECStack = [];

試想當JavaScript開始要解釋執行代碼的時候,最先遇到的 就是全局代碼,所以初始化的時候首先就會向執行上下文棧壓入一個全局執行上下文,我們用globalContext表示它,并且只有當整個應用程序結束的時候,ECStack才會被清空,所以程序結束之前,ECStack最底部永遠有個globalContext

ECStack = [globalContext
];

當JavaScript遇到下面的這段代碼了:

function fun3(){console.log('fun3');
}
function fun2(){fun3();
}
function fun1(){fun2();
}
fun1();

當執行一個函數的時候,就會創建一個執行上下文,并且壓入執行上下文棧,當函數執行完畢的時候,就會將函數的執行上下文從棧中彈出。知道了這樣的工作原理,讓我們來看看如何處理上面這段代碼:

//偽代碼
//fun1()
ESCtack.push(<fun1> functionContext);//入棧
//fun1中竟然調用了fun2,還要創建fun2的執行上下文
ESCtack.push(<fun2> functionContext);//入棧
//fun2還調用了fun3!
ESCtack.push(<fun3> functionContext);//入棧
//fun3執行完畢
ESCtack.pop();//出棧
//fun2執行完畢
ESCtack.pop();//出棧
//fun1執行完畢
ESCtack.pop();//出棧
//javascript接著執行下面的代碼,但是ESCtack底層永遠有個globalContext

回顧上文

//case 1
var scope = "global scope";
function checkscope(){var scope = "local scope";function f(){return scope;}return f();
}
checkscope();//case 2
var scope = "global scope";
function checkscope(){var scope = "local scope";function f(){return scope;}return f;
}
checkscope()();

兩段代碼執行的結果一樣,但是兩段代碼究竟有哪些不同呢?
答案是:執行上下文棧的變化不一樣。
模擬第一段代碼:

ECStack.push(<checkscope> functionContext);//入棧
ECStack.push(<f> functionContext);//入棧
ECStack.pop();//出棧
ECStack.pop();//出棧

模擬第二段:

ECStack.push(<checkscope> functionContext);
ECStack.pop();//出棧
ECStack.push(<f> functionContext);//入棧
ECStack.pop()//出棧

這就是上文說到的區別。

好啦!這期就到這里啦,歡迎友友們留言討論吶~
在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/214942.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/214942.shtml
英文地址,請注明出處:http://en.pswp.cn/news/214942.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

HTML面試題---專題一

文章目錄 一、前言二、 HTML5 中 <header> 和 <footer> 標簽的用途是什么&#xff1f;三、如何在 HTML 中嵌入 SVG&#xff08;可縮放矢量圖形&#xff09;文件&#xff1f;四、解釋 contenteditable 屬性的用途五、如何創建隨屏幕尺寸縮放的響應式圖像&#xff1f…

八大排序算法【上】

冒泡排序 冒泡排序是一種 穩定 的排序算法。 它的工作原理是每次檢查相鄰兩個元素&#xff0c;如果前面的元素與后面的元素滿足給定的排序條件&#xff0c;就將相鄰兩個元素交換。當沒有相鄰的元素需要交換時&#xff0c;排序就完成了。 假設我們想要從小到大進行排序&#…

大模型:常見的文字表情包(可以直接加到微調數據里)

大模型&#xff1a;常見的文字表情包(可以直接加到微調數據里) 返回論文目錄 返回資料目錄 表情符號含義&#x1f60a;愉快、微笑&#x1f602;大笑&#x1f60d;愛心眼&#x1f60e;酷、自信&#x1f914;思考、疑惑&#x1f61c;調皮、頑皮&#x1f64c;鼓掌、慶祝&#x1f…

線上扭蛋機小程序搭建,扭蛋與科技的完美結合

扭蛋機作為當下比較熱門的一種盲盒玩法&#xff0c;在年輕人群體中非常受歡迎。隨著經濟的增長和人們生活水平的提高&#xff0c;人們對娛樂消費需求也在增加&#xff0c;扭蛋機的受眾群體也在擴大。 目前線上扭蛋機小程序也獲得了大眾的青睞&#xff0c;扭蛋機小程序就是把線…

記錄一下快速上手Springboot登錄注冊項目

本教程需要安裝以下工具&#xff0c;如果不清楚怎么安裝的可以看下我的這篇文章 鏈接: https://blog.csdn.net/qq_30627241/article/details/134804675 管理工具&#xff1a; maven IDE&#xff1a; IDEA 數據庫&#xff1a; MySQL 測試工具&#xff1a; Postman 打開IDE…

Ansys結構靜力學仿真的一般流程

1. 模型實體 三維幾何模型的構建。 2. 材料屬性 根據實際情況&#xff0c;為模型中的各個部分定義材料屬性&#xff0c;包括彈性模量、泊松比、密度等。 3. 單元類型 node 結點數等 4. 網格劃分 網格屬性&#xff08;尺寸&#xff09; 5. 邊界條件 這個定義有點模糊&#x…

AR-LDM原理及代碼分析

AR-LDM原理AR-LDM代碼分析pytorch_lightning(pl)的hook流程main.py 具體分析TrainSampleLightningDatasetARLDM blip mm encoder AR-LDM原理 左邊是模仿了自回歸地從1, 2, ..., j-1來構造 j 時刻的 frame 的過程。 在普通Stable Diffusion的基礎上&#xff0c;使用了1, 2, .…

天池SQL訓練營(六)-綜合練習題-10道經典題目

如果你還沒有學習過SQL訓練營的以下知識&#xff0c;請查閱主頁博文學習&#xff1a; Task 1 SQL基礎&#xff1a;初識數據庫與SQL-安裝與基本介紹等 Task 2 SQL基礎&#xff1a;查詢與排序-select、運算符、聚合分組查詢等 Task 3 SQL進階&#xff1a;復雜查詢方法-視圖、子查…

網工內推 | 項目經理專場,最高20K*13薪,軟考證書優先

01 Trasen 招聘崗位&#xff1a;大項目經理&#xff08;醫療行業/HIS&#xff09; 職責描述&#xff1a; 1.負責項目按計劃完成交付并順利驗收結項&#xff1b; 2.參與項目前期預算、評審、方案設計等&#xff1b; 3.負責具體項目實施&#xff0c;制定項目計劃、組織項目資源、…

Web網站服務(二)

1、客戶機地址限制。 Require all granted&#xff1a;表示允許所有主機訪問。 Require all denied&#xff1a;表示拒絕所有主機訪問。 Require local&#xff1a;表示僅允許本地主機訪問。 Require [not] host <主機名或域名列表>&#xff1a;表示允許或拒絕指定主機或…

Web安全-SQL注入【sqli靶場第11-14關】(三)

★★實戰前置聲明★★ 文章中涉及的程序(方法)可能帶有攻擊性&#xff0c;僅供安全研究與學習之用&#xff0c;讀者將其信息做其他用途&#xff0c;由用戶承擔全部法律及連帶責任&#xff0c;文章作者不承擔任何法律及連帶責任。 0、總體思路 先確認是否可以SQL注入&#xff0…

輕空間助力中國高校實現場館多功能一體化

中國高校在迎接體育、文藝、學術等多元化需求的同時&#xff0c;面臨著場館設施不足、建設成本高的難題。然而&#xff0c;隨著輕空間&#xff08;江蘇&#xff09;膜科技有限公司的嶄新解決方案的引入&#xff0c;中國高校如蘇州大學等正迎來一場場館多功能一體化的革命。 創新…

電源小白入門學習4——LDO的選擇與使用技巧

電源小白入門學習4——LDO的選擇與使用技巧 LDO簡介LDO工作原理LDO選型LDO并聯問題LDO的新發展 上期我們介紹了開關電源系統中一些常見的元器件&#xff0c;這期我們來學習LDO的選擇與使用技巧 LDO簡介 LDO的全稱是低壓差線性穩壓器&#xff08;Low Drop-Out Linear Regulator…

python的os模塊(一)

os 模塊提供了非常豐富的方法用來處理文件和目錄。常用的方法如下表所示&#xff1a; 一.os.getcwd 相當于shell的 pwd&#xff0c;查看當前目錄 [rootrhel8 day06]# vim demo01.py import os print(os.getcwd()) #查看當前目錄[rootrhel8 day06]# python3 demo01.py /root/m…

計算機病毒判定專家系統原理與設計《文字提取人工修正》

內容源于網絡。網絡上流轉的版本實在是不易閱讀&#xff0c; 又不忍神作被糟蹋故稍作整理&#xff0c;對于內容仍然有識別不準的地方&#xff0c;網友可留言&#xff0c;我跟進修改。 雷 軍 &#xff08;武漢大學計算機系&#xff0c;430072) 摘要: 本文詳細地描述了…

Rust的未來發展趨勢和行業應用

大家好&#xff01;我是lincyang。 今天&#xff0c;我們來深入探討Rust的未來發展趨勢以及它在各個行業中的應用情況。 自從Rust語言問世以來&#xff0c;它以其獨特的安全性和高效性在編程界引起了廣泛關注。Rust的設計理念主要集中在安全、速度和并發三個方面&#xff0c;…

【數值計算方法(黃明游)】數值積分(一):復化(梯形公式、中點公式)【理論到程序】

? 文章目錄 一、梯形公式、中點公式1. 梯形公式&#xff08;Trapezoidal Rule&#xff09;&#xff1a;2. 復化梯形公式&#xff08;Composite Trapezoidal Rule&#xff09;&#xff1a;3. 中點公式&#xff08;Midpoint Rule&#xff09;&#xff1a;4. 復化中點公式&#…

算法通關村第十五關 | 黃金 | 超大規模數據場景

1.對 20GB 文件進行排序 有一個 20GB 的文件&#xff0c;每行一個字符串&#xff0c;對其進行排序。 這里可以使用分塊方式來排序&#xff0c;先將每塊進行排序&#xff0c;然后要逐步進行合并&#xff0c;也叫做外部排序。 2.超大文本中搜索兩個單詞的最短距離 有一個超大…

【UML】NO.2 UML必須了解的基礎知識(舉例)

目錄 一、UML的構成 1.1 事物 1.2 關系 1.3 圖 二、事物 2.1 結構事物 2.1.1 類&#xff08;class&#xff09; 2.1.2 接口 2.1.3 協作 2.1.4 用例 2.1.5 主動類 2.1.6 構件 2.1.7 節點 2.2 行為事物 2.2.1 交互 2.2.2 狀態機 2.2.3 活動 2.3 分組事物 包 …