談?wù)勎覍avaScript原型和閉包系列理解(隨手筆記8)
在上篇文章給大家介紹了《談?wù)勎覍avaScript原型和閉包系列理解(隨手筆記6)》, 談?wù)勎覍avaScript原型和閉包系列理解(隨手筆記9) 可以點擊了解詳情。
執(zhí)行上下文棧
執(zhí)行全局代碼時,會產(chǎn)生一個執(zhí)行上下文環(huán)境,每次調(diào)用函數(shù)都又會產(chǎn)生執(zhí)行上下文環(huán)境。當函數(shù)調(diào)用完成時,這個上下文環(huán)境以及其中的數(shù)據(jù)都會被消除,再重新回到全局上下文環(huán)境。處于活動狀態(tài)的執(zhí)行上下文環(huán)境只有一個。
壓棧出棧過程----執(zhí)行上下文棧:
var a = 10, //1. 進入全局上下文環(huán)境 fn, bar = function(x) { var b = 5; fn(x + b); //3. 進入fn函數(shù)上下文 }; fn = function(y) { var c = 5; console.log(y + c); }; bar(10); //2. 進入bar函數(shù)上下文環(huán)境
1、在執(zhí)行之前,首先創(chuàng)建全局上下文環(huán)境
2、代碼執(zhí)行,執(zhí)行到bar(10)之前,全局上下文中的變量在執(zhí)行過程中被賦值。
3、執(zhí)行到bar(10)調(diào)用bar函數(shù),同時創(chuàng)建該函數(shù)內(nèi)部的執(zhí)行上下文環(huán)境
4、這時候該執(zhí)行上下文環(huán)境進行壓棧,設(shè)置為活動狀態(tài)
5、bar函數(shù)執(zhí)行到fn(x + b),調(diào)用fn函數(shù),創(chuàng)建了fn函數(shù)的執(zhí)行上下文,并壓棧,設(shè)置為活動狀態(tài)
6、fn函數(shù)執(zhí)行完畢,fn環(huán)境出棧,被銷毀,釋放內(nèi)存,bar函數(shù)變?yōu)榛顒討B(tài)
7、fn函數(shù)執(zhí)行完畢并銷毀,意味著bar也執(zhí)行完畢了,此時bar函數(shù)環(huán)境出棧,并銷毀。全局環(huán)境變?yōu)榛顒討B(tài)。
到這里這一段代碼的執(zhí)行過程就完畢了。
根據(jù)原作者的描述:
其中上下文環(huán)境的變量賦值過程我省略了許多,因為那些并不難,一看就知道。
的確!代碼的大概執(zhí)行過程跑完后,就能很清楚的知道各個執(zhí)行環(huán)境中的變量是個怎樣的狀態(tài)。
講到這里,我不得不很遺憾的跟大家說:其實以上我們所演示的是一種比較理想的情況。有一種情況,而且是很常用的一種情況,無法做到這樣干凈利落的說銷毀就銷毀。這種情況就是偉大的——閉包。要說閉包,咱們還得先從自由變量和作用域說起。
以上內(nèi)容是小編給大家分享我對JavaScript原型和閉包系列理解(隨手筆記8),希望大家喜歡。
相關(guān)文章
javascript?ES6中set集合、map集合使用方法詳解與源碼實例
這篇文章主要介紹了javascript?ES6中set、map使用方法詳解與源碼實例,需要的朋友可以參考下2022-12-12基于JavaScript實現(xiàn)Json數(shù)據(jù)根據(jù)某個字段進行排序
這篇文章主要介紹了基于JavaScript實現(xiàn)Json數(shù)據(jù)根據(jù)某個字段進行排序的相關(guān)資料,需要的朋友可以參考下2015-11-11中級前端工程師必須要掌握的27個JavaScript 技巧(干貨總結(jié))
這篇文章主要介紹了中級前端工程師必須要掌握的27個JavaScript 技巧(干貨總結(jié)),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-09-09javascript trim 去空格函數(shù)實現(xiàn)代碼
去除字符串左右兩端的空格,在vbscript里面可以輕松地使用 trim、ltrim 或 rtrim,但在js中卻沒有這3個內(nèi)置方法,需要手工編寫。下面的實現(xiàn)方法是用到了正則表達式,效率不錯,并把這三個方法加入String對象的內(nèi)置方法中去。2008-10-10