JavaScript預(yù)編譯原理分析

大家要明白,這個(gè)預(yù)編譯和傳統(tǒng)的編譯是不一樣的(可以理解js預(yù)編譯為特殊的編譯過(guò)程)
JavaScript是解釋型語(yǔ)言絮记,
既然是解釋型語(yǔ)言恢准,就是編譯一行戳气,執(zhí)行一行
傳統(tǒng)的編譯會(huì)經(jīng)歷很多步驟,分詞吸占、解析晴叨、代碼生成什么的
日后有時(shí)間再給大家科普
下面就給大家分享一下我所理解的JS預(yù)編譯

JavaScript運(yùn)行三部曲

腳本執(zhí)行js引擎都做了什么呢?

  1. 語(yǔ)法分析
  2. 預(yù)編譯
  3. 解釋執(zhí)行

語(yǔ)法分析很簡(jiǎn)單矾屯,就是引擎檢查你的代碼有沒(méi)有什么低級(jí)的語(yǔ)法錯(cuò)誤
解釋執(zhí)行顧名思義便是執(zhí)行代碼了
預(yù)編譯簡(jiǎn)單理解就是在內(nèi)存中開(kāi)辟一些空間兼蕊,存放一些變量與函數(shù)
理解了預(yù)編譯對(duì)大家理解作用域同樣有幫助

JS預(yù)編譯什么時(shí)候發(fā)生

預(yù)編譯到底什么時(shí)候發(fā)生
希望大家不要讓上面的運(yùn)行過(guò)程讓你產(chǎn)生誤會(huì),
誤以為預(yù)編譯僅僅發(fā)生在script內(nèi)代碼塊執(zhí)行前
這倒并沒(méi)有錯(cuò)
預(yù)編譯確確實(shí)實(shí)在script代碼內(nèi)執(zhí)行前發(fā)生了
但是它都會(huì)發(fā)生在函數(shù)執(zhí)行前

JS預(yù)編譯實(shí)例

舉例前件蚕,先來(lái)思考一下這幾個(gè)概念:

  • 變量聲明 var
  • 函數(shù)聲明 function
<script>
    var a = 1;// 變量聲明
    function b(y){//函數(shù)聲明
        var x = 1;
        console.log('so easy');
    };
    var c = function(){//是變量聲明而不是函數(shù)聲明K锛肌!
        //...
    }
    b(100);
</script>
<script>
    var d = 0;
</script>

讓我們看看引擎對(duì)這段代碼做了什么吧

  • 頁(yè)面產(chǎn)生便創(chuàng)建了GO全局對(duì)象(Global Object)(也就是大家熟悉的window對(duì)象)
  • 第一個(gè)腳本文件加載
  • 腳本加載完畢后骤坐,分析語(yǔ)法是否合法
  • 開(kāi)始預(yù)編譯
    • 查找變量聲明绪杏,作為GO屬性,值賦予undefined
    • 查找函數(shù)聲明纽绍,作為GO屬性蕾久,值賦予函數(shù)體
//偽代碼
GO/window = {
    //頁(yè)面加載創(chuàng)建GO同時(shí),創(chuàng)建了document拌夏、navigator僧著、screen等等屬性履因,此處省略
    a: undefined,
    c: undefined,
    b: function(y){
        var x = 1;
        console.log('so easy');
    }
}
  • 解釋執(zhí)行代碼(直到執(zhí)行函數(shù)b)
//偽代碼
GO/window = {
    //變量隨著執(zhí)行流得到初始化
    a: 1,
    c: function(){
        //...
    },
    b: function(y){
        var x = 1;
        console.log('so easy');
    }
}
  • 執(zhí)行函數(shù)b之前盹愚,發(fā)生預(yù)編譯
    • 創(chuàng)建AO活動(dòng)對(duì)象(Active Object)
    • 查找形參和變量聲明栅迄,值賦予undefined
    • 實(shí)參值賦給形參
    • 查找函數(shù)聲明,值賦予函數(shù)體
//偽代碼
AO = {
    //創(chuàng)建AO同時(shí)皆怕,創(chuàng)建了arguments等等屬性毅舆,此處省略
    y: 100,
    x: undefined
}
  • 解釋執(zhí)行函數(shù)中代碼
  • 第一個(gè)腳本文件執(zhí)行完畢,加載第二個(gè)腳本文件
  • 第二個(gè)腳本文件加載完畢后愈腾,進(jìn)行語(yǔ)法分析
  • 語(yǔ)法分析完畢憋活,開(kāi)始預(yù)編譯
    • 重復(fù)最開(kāi)始的預(yù)編譯步驟

大家要注意:
預(yù)編譯階段發(fā)生變量聲明和函數(shù)聲明,沒(méi)有初始化行為(賦值)虱黄,匿名函數(shù)不參與預(yù)編譯只有在解釋執(zhí)行階段才會(huì)進(jìn)行變量初始化

總結(jié)

預(yù)編譯(函數(shù)執(zhí)行前)

  1. 創(chuàng)建AO對(duì)象(Active Object)
  2. 查找函數(shù)形參及函數(shù)內(nèi)變量聲明悦即,形參名及變量名作為AO對(duì)象的屬性,值為undefined
  3. 實(shí)參形參相統(tǒng)一橱乱,實(shí)參值賦給形參
  4. 查找函數(shù)聲明辜梳,函數(shù)名作為AO對(duì)象的屬性,值為函數(shù)引用

預(yù)編譯(腳本代碼塊script執(zhí)行前)

  1. 查找全局變量聲明(包括隱式全局變量聲明泳叠,省略var聲明)作瞄,變量名作全局對(duì)象的屬性,值為undefined
  2. 查找函數(shù)聲明析二,函數(shù)名作為全局對(duì)象的屬性粉洼,值為函數(shù)引用

作者:accelerator
來(lái)源:CSDN
原文:https://blog.csdn.net/q1056843325/article/details/52951114
版權(quán)聲明:本文為博主原創(chuàng)文章,轉(zhuǎn)載請(qǐng)附上博文鏈接叶摄!

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末属韧,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子蛤吓,更是在濱河造成了極大的恐慌宵喂,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,311評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件会傲,死亡現(xiàn)場(chǎng)離奇詭異锅棕,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)淌山,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén)裸燎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人泼疑,你說(shuō)我怎么就攤上這事德绿。” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,671評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵移稳,是天一觀(guān)的道長(zhǎng)蕴纳。 經(jīng)常有香客問(wèn)我,道長(zhǎng)个粱,這世上最難降的妖魔是什么古毛? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,252評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮都许,結(jié)果婚禮上稻薇,老公的妹妹穿的比我還像新娘。我一直安慰自己梭稚,他們只是感情好颖低,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,253評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著弧烤,像睡著了一般。 火紅的嫁衣襯著肌膚如雪蹬敲。 梳的紋絲不亂的頭發(fā)上暇昂,一...
    開(kāi)封第一講書(shū)人閱讀 49,031評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音伴嗡,去河邊找鬼急波。 笑死,一個(gè)胖子當(dāng)著我的面吹牛瘪校,可吹牛的內(nèi)容都是我干的澄暮。 我是一名探鬼主播,決...
    沈念sama閱讀 38,340評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼阱扬,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼泣懊!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起麻惶,我...
    開(kāi)封第一講書(shū)人閱讀 36,973評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤馍刮,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后窃蹋,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體卡啰,經(jīng)...
    沈念sama閱讀 43,466評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,937評(píng)論 2 323
  • 正文 我和宋清朗相戀三年警没,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了匈辱。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,039評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡杀迹,死狀恐怖亡脸,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤梗掰,帶...
    沈念sama閱讀 33,701評(píng)論 4 323
  • 正文 年R本政府宣布嵌言,位于F島的核電站,受9級(jí)特大地震影響及穗,放射性物質(zhì)發(fā)生泄漏摧茴。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,254評(píng)論 3 307
  • 文/蒙蒙 一埂陆、第九天 我趴在偏房一處隱蔽的房頂上張望苛白。 院中可真熱鬧,春花似錦焚虱、人聲如沸购裙。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,259評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)躏率。三九已至,卻和暖如春民鼓,著一層夾襖步出監(jiān)牢的瞬間薇芝,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工丰嘉, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留夯到,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,497評(píng)論 2 354
  • 正文 我出身青樓饮亏,卻偏偏與公主長(zhǎng)得像耍贾,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子路幸,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,786評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • Swift1> Swift和OC的區(qū)別1.1> Swift沒(méi)有地址/指針的概念1.2> 泛型1.3> 類(lèi)型嚴(yán)謹(jǐn) 對(duì)...
    cosWriter閱讀 11,089評(píng)論 1 32
  • 首先,JavaScript確實(shí)是一門(mén)編譯型語(yǔ)言着帽,與C等典型編譯型語(yǔ)言相比杂伟,區(qū)別在于JavaScript的編譯過(guò)程(...
    環(huán)零弦閱讀 5,556評(píng)論 0 18
  • 為什么要有.gitignore文件 項(xiàng)目中經(jīng)常會(huì)生成一些Git系統(tǒng)不需要追蹤(track)的文件。典型的是在編譯生...
    shadow雨軒閱讀 10,092評(píng)論 0 0
  • 運(yùn)營(yíng)其實(shí)就是連接產(chǎn)品和用戶(hù)的通道。有機(jī)的運(yùn)營(yíng)能使兩者之間產(chǎn)生持續(xù)良性的發(fā)展關(guān)系予借。有別于傳統(tǒng)行業(yè)越平,互聯(lián)網(wǎng)行業(yè)...
    公子小卿閱讀 286評(píng)論 1 1
  • 今天下班匆忙趕回家频蛔,然后帶閨女去區(qū)里的婦幼保健醫(yī)院,來(lái)了以后我們就好好檢查秦叛,大夫居然說(shuō)閨女是敏感體質(zhì)晦溪,現(xiàn)在可有鼻炎...
    醒時(shí)只在花間坐閱讀 148評(píng)論 0 1