資料介紹
1. 詞法分析
詞法分析器根據(jù)詞法規(guī)則識(shí)別出源程序中的各個(gè)記號(hào)(token),每個(gè)記號(hào)代表一類單詞(lexeme)。源程序中常見的記號(hào)可以歸為幾大類:關(guān)鍵字、標(biāo)識(shí)符、字面量和特殊符號(hào)。詞法分析器的輸入是源程序,輸出是識(shí)別的記號(hào)流。詞法分析器的任務(wù)是把源文件的字符流轉(zhuǎn)換成記號(hào)流。本質(zhì)上它查看連續(xù)的字符然后把它們識(shí)別為“單詞”。
2. 語法分析
語法分析器根據(jù)語法規(guī)則識(shí)別出記號(hào)流中的結(jié)構(gòu)(短語、句子),并構(gòu)造一棵能夠正確反映該結(jié)構(gòu)的語法樹。
3. 語義分析
語義分析器根據(jù)語義規(guī)則對(duì)語法樹中的語法單元進(jìn)行靜態(tài)語義檢查,如果類型檢查和轉(zhuǎn)換等,其目的在于保證語法正確的結(jié)構(gòu)在語義上也是合法的。
4. 中間代碼生成
中間代碼生成器根據(jù)語義分析器的輸出生成中間代碼。中間代碼可以有若干種形式,它們的共同特征是與具體機(jī)器無關(guān)。最常用的一種中間代碼是三地址碼,它的一種實(shí)現(xiàn)方式是四元式。三地址碼的優(yōu)點(diǎn)是便于閱讀、便于優(yōu)化。
5. 中間代碼優(yōu)化
優(yōu)化是編譯器的一個(gè)重要組成部分,由于編譯器將源程序翻譯成中間代碼的工作是機(jī)械的、按固定模式進(jìn)行的,因此,生成的中間代碼往往在時(shí)間和空間上有很大浪費(fèi)。當(dāng)需要生成高效目標(biāo)代碼時(shí),就必須進(jìn)行優(yōu)化。
6. 目標(biāo)代碼生成
目標(biāo)代碼生成是編譯器的最后一個(gè)階段。在生成目標(biāo)代碼時(shí)要考慮以下幾個(gè)問題:計(jì)算機(jī)的系統(tǒng)結(jié)構(gòu)、指令系統(tǒng)、寄存器的分配以及內(nèi)存的組織等。編譯器生成的目標(biāo)程序代碼可以有多種形式:匯編語言、可重定位二進(jìn)制代碼、內(nèi)存形式。
7 符號(hào)表管理
符號(hào)表的作用是記錄源程序中符號(hào)的必要信息,并加以合理組織,從而在編譯器的各個(gè)階段能對(duì)它們進(jìn)行快速、準(zhǔn)確的查找和操作。符號(hào)表中的某些內(nèi)容甚至要保留到程序的運(yùn)行階段。
8 出錯(cuò)處理
用戶編寫的源程序中往往會(huì)有一些錯(cuò)誤,可分為靜態(tài)錯(cuò)誤和動(dòng)態(tài)錯(cuò)誤兩類。所謂動(dòng)態(tài)錯(cuò)誤,是指源程序中的邏輯錯(cuò)誤,它們發(fā)生在程序運(yùn)行的時(shí)候,也被稱作動(dòng)態(tài)語義錯(cuò)誤,如變量取值為零時(shí)作為除數(shù),數(shù)組元素引用時(shí)下標(biāo)出界等。靜態(tài)錯(cuò)誤又可分為語法錯(cuò)誤和靜態(tài)語義錯(cuò)誤。語法錯(cuò)誤是指有關(guān)語言結(jié)構(gòu)上的錯(cuò)誤,如單詞拼寫錯(cuò)、表達(dá)式中缺少操作數(shù)、begin和end不匹配等。靜態(tài)語義錯(cuò)誤是指分析源程序時(shí)可以發(fā)現(xiàn)的語言意義上的錯(cuò)誤,如加法的兩個(gè)操作數(shù)中一個(gè)是整型變量名,而另一個(gè)是數(shù)組名等。
?
詞法分析器根據(jù)詞法規(guī)則識(shí)別出源程序中的各個(gè)記號(hào)(token),每個(gè)記號(hào)代表一類單詞(lexeme)。源程序中常見的記號(hào)可以歸為幾大類:關(guān)鍵字、標(biāo)識(shí)符、字面量和特殊符號(hào)。詞法分析器的輸入是源程序,輸出是識(shí)別的記號(hào)流。詞法分析器的任務(wù)是把源文件的字符流轉(zhuǎn)換成記號(hào)流。本質(zhì)上它查看連續(xù)的字符然后把它們識(shí)別為“單詞”。
2. 語法分析
語法分析器根據(jù)語法規(guī)則識(shí)別出記號(hào)流中的結(jié)構(gòu)(短語、句子),并構(gòu)造一棵能夠正確反映該結(jié)構(gòu)的語法樹。
3. 語義分析
語義分析器根據(jù)語義規(guī)則對(duì)語法樹中的語法單元進(jìn)行靜態(tài)語義檢查,如果類型檢查和轉(zhuǎn)換等,其目的在于保證語法正確的結(jié)構(gòu)在語義上也是合法的。
4. 中間代碼生成
中間代碼生成器根據(jù)語義分析器的輸出生成中間代碼。中間代碼可以有若干種形式,它們的共同特征是與具體機(jī)器無關(guān)。最常用的一種中間代碼是三地址碼,它的一種實(shí)現(xiàn)方式是四元式。三地址碼的優(yōu)點(diǎn)是便于閱讀、便于優(yōu)化。
5. 中間代碼優(yōu)化
優(yōu)化是編譯器的一個(gè)重要組成部分,由于編譯器將源程序翻譯成中間代碼的工作是機(jī)械的、按固定模式進(jìn)行的,因此,生成的中間代碼往往在時(shí)間和空間上有很大浪費(fèi)。當(dāng)需要生成高效目標(biāo)代碼時(shí),就必須進(jìn)行優(yōu)化。
6. 目標(biāo)代碼生成
目標(biāo)代碼生成是編譯器的最后一個(gè)階段。在生成目標(biāo)代碼時(shí)要考慮以下幾個(gè)問題:計(jì)算機(jī)的系統(tǒng)結(jié)構(gòu)、指令系統(tǒng)、寄存器的分配以及內(nèi)存的組織等。編譯器生成的目標(biāo)程序代碼可以有多種形式:匯編語言、可重定位二進(jìn)制代碼、內(nèi)存形式。
7 符號(hào)表管理
符號(hào)表的作用是記錄源程序中符號(hào)的必要信息,并加以合理組織,從而在編譯器的各個(gè)階段能對(duì)它們進(jìn)行快速、準(zhǔn)確的查找和操作。符號(hào)表中的某些內(nèi)容甚至要保留到程序的運(yùn)行階段。
8 出錯(cuò)處理
用戶編寫的源程序中往往會(huì)有一些錯(cuò)誤,可分為靜態(tài)錯(cuò)誤和動(dòng)態(tài)錯(cuò)誤兩類。所謂動(dòng)態(tài)錯(cuò)誤,是指源程序中的邏輯錯(cuò)誤,它們發(fā)生在程序運(yùn)行的時(shí)候,也被稱作動(dòng)態(tài)語義錯(cuò)誤,如變量取值為零時(shí)作為除數(shù),數(shù)組元素引用時(shí)下標(biāo)出界等。靜態(tài)錯(cuò)誤又可分為語法錯(cuò)誤和靜態(tài)語義錯(cuò)誤。語法錯(cuò)誤是指有關(guān)語言結(jié)構(gòu)上的錯(cuò)誤,如單詞拼寫錯(cuò)、表達(dá)式中缺少操作數(shù)、begin和end不匹配等。靜態(tài)語義錯(cuò)誤是指分析源程序時(shí)可以發(fā)現(xiàn)的語言意義上的錯(cuò)誤,如加法的兩個(gè)操作數(shù)中一個(gè)是整型變量名,而另一個(gè)是數(shù)組名等。
?
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 基于GCC實(shí)現(xiàn)支持MISRAC的安全編譯器
- 基于C++編譯器的節(jié)點(diǎn)融合優(yōu)化方法 19次下載
- CompCert編譯器目標(biāo)代碼生成機(jī)制研究綜述 4次下載
- C語言編譯器常見的預(yù)編譯指令詳細(xì)資料說明
- AVR程序編譯器avrubd應(yīng)用程序免費(fèi)下載 52次下載
- 如何解決proteus的c編譯器問題的方法 26次下載
- MPLAB C18編譯器到MPLAB XC8 C編譯器的移植過程詳細(xì)中文資料概述
- 如何將C源代碼從MPLAB C18編譯器移植到MPLAB XC8C編譯器的詳細(xì)概述
- NEC編譯器培訓(xùn)手冊(cè) 15次下載
- PICC編譯器下載 168次下載
- C語言編譯器 50次下載
- 基于CoSy的編譯器開發(fā)的研究 0次下載
- ICC AVR編譯器的安裝與使用
- INTEL的PLM51編譯器
- AVRC (AVR的PASCAL編譯器)
- Triton編譯器的原理和性能 2165次閱讀
- TVM編譯器的整體架構(gòu)和基本方法 1824次閱讀
- C程序的完整編譯過程 1797次閱讀
- 領(lǐng)域編譯器發(fā)展的前世今生 1472次閱讀
- 交叉編譯器安裝教程 3269次閱讀
- VScode編譯器如何配置C/C++編譯環(huán)境 5431次閱讀
- 編譯器優(yōu)化對(duì)函數(shù)的影響 2734次閱讀
- 虛擬機(jī):編譯器對(duì)C函數(shù)的名字修飾 2469次閱讀
- 如何選擇PIC單片機(jī)的C編譯器 5245次閱讀
- 深入編程語言和編譯器是怎樣工作的 4212次閱讀
- 編譯器原理到底是怎樣的帶你簡(jiǎn)單的了解編譯器原理 1.1w次閱讀
- verilog編譯指令_verilog編譯器指示語句(數(shù)字IC) 1.4w次閱讀
- 用于linux系統(tǒng)下編程的編譯器,掌握gcc的基本用法 5579次閱讀
- 編譯器是如何工作的_編譯器的工作過程詳解 1.5w次閱讀
- 編譯器跟編輯器有什么區(qū)別 2.9w次閱讀
下載排行
本周
- 1電子電路原理第七版PDF電子教材免費(fèi)下載
- 0.00 MB | 1489次下載 | 免費(fèi)
- 2單片機(jī)典型實(shí)例介紹
- 18.19 MB | 91次下載 | 1 積分
- 3S7-200PLC編程實(shí)例詳細(xì)資料
- 1.17 MB | 27次下載 | 1 積分
- 4筆記本電腦主板的元件識(shí)別和講解說明
- 4.28 MB | 18次下載 | 4 積分
- 5開關(guān)電源原理及各功能電路詳解
- 0.38 MB | 9次下載 | 免費(fèi)
- 6基于AT89C2051/4051單片機(jī)編程器的實(shí)驗(yàn)
- 0.11 MB | 4次下載 | 免費(fèi)
- 7基于單片機(jī)和 SG3525的程控開關(guān)電源設(shè)計(jì)
- 0.23 MB | 3次下載 | 免費(fèi)
- 8基于單片機(jī)的紅外風(fēng)扇遙控
- 0.23 MB | 3次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費(fèi)
- 2PADS 9.0 2009最新版 -下載
- 0.00 MB | 66304次下載 | 免費(fèi)
- 3protel99下載protel99軟件下載(中文版)
- 0.00 MB | 51209次下載 | 免費(fèi)
- 4LabView 8.0 專業(yè)版下載 (3CD完整版)
- 0.00 MB | 51043次下載 | 免費(fèi)
- 5555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33562次下載 | 免費(fèi)
- 6接口電路圖大全
- 未知 | 30319次下載 | 免費(fèi)
- 7Multisim 10下載Multisim 10 中文版
- 0.00 MB | 28588次下載 | 免費(fèi)
- 8開關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21539次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935053次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537791次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233045次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191183次下載 | 免費(fèi)
- 7十天學(xué)會(huì)AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183277次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138039次下載 | 免費(fèi)
評(píng)論
查看更多