編譯原理教程(第三版)(胡元義)

編譯原理教程(第三版)(胡元義)

《編譯原理教程(第三版)(胡元義)》是2014年西安電子科技大學出版社出版的圖書,作者是胡元義。

內容簡介

本書系統地介紹了編譯程式的設計原理及實現技術,主要內容包括:緒論、詞法分析、語法分析、語義分析和中間代碼生成、代碼最佳化、目標程式運行時存儲空間的組織、目標代碼生成、符號表與錯誤處理等。

在內容的組織上,本書強調知識的實用性,將編譯的基本理論與具體的實現技術有機地結合起來,既注重了理論的完整性,化繁為簡,又將理論融於具體的實例中,化難為易,以達到準確、清楚地闡述相關概念和原理的目的。本書注重各章節對理論闡述的條理性,書中給出的例子也具有較強的實用性與連貫性,使讀者對編譯的各個階段有一個全面、直觀的認識。本書採用的算法全部由C語言描述,各章均附有習題。

本書可作為計算機本科專業的教材,也可作為計算機軟體工程人員的參考資料。

目錄

第一章 緒論 1

1.1 程式設計語言和編譯程式 1

1.2 編譯程式的歷史及發展 3

1.3 編譯過程和編譯程式結構 4

1.4 編譯程式的開發 5

1.5 構造編譯程式所應具備的知識內容 6

習題一 8

第二章 詞法分析 9

2.1 詞法分析器的設計方法 9

2.1.1 單詞符號的分類與輸出形式 9

2.1.2 狀態轉換圖 10

2.2 一個簡單的詞法分析器示例 12

2.2.1 C語言子集的單詞符號表示 12

2.2.2 C語言子集對應的狀態轉換圖 12

2.2.3 狀態轉換圖的實現 13

2.3 正規表達式與有限自動機簡介 16

2.3.1 正規表達式與正規集 16

2.3.2 有限自動機 17

2.4 正規表達式到有限自動機的構造 20

2.4.1 由正規表達式構造等價的非確定有限自動機(NFA) 20

2.4.2 NFA的確定化 21

2.4.3 確定有限自動機(DFA)的化簡 22

2.4.4 正規表達式到有限自動機構造示例 24

2.5 詞法分析器的自動生成 28

習題二 30

第三章 語法分析 33

3.1 文法和語言 33

3.1.1 文法和語言的基本概念 33

3.1.2 形式語言分類 36

3.1.3 正規表達式與上下文無關文法 38

3.2 推導與語法樹 39

3.2.1 推導與短語 39

3.2.2 語法樹與二義性 40

3.3 自頂向下的語法分析 44

3.3.1 遞歸下降分析法 44

3.3.2 LL(1)分析法 52

3.4 自底向上的語法分析 58

3.4.1 自底向上分析原理 58

3.4.2 算符優先分析法 60

3.5 規範歸約的自底向上語法分析方法 70

3.5.1 LR分析器的工作原理 70

3.5.2 LR(0)分析器 73

3.5.3 SLR(1)分析器 78

3.5.4 LR(1)分析器 81

3.5.5 LALR分析器 86

3.5.6 二義文法的套用 88

*3.5.7 LR分析器套用與拓展 92

習題三 93

第四章 語義分析和中間代碼生成 101

4.1 概述 101

4.1.1 語義分析的概念 101

4.1.2 語法制導翻譯方法 101

4.2 屬性文法 103

4.2.1 文法的屬性 103

4.2.2 屬性文法 103

4.3 幾種常見的中間語言 105

4.3.1 抽象語法樹 105

4.3.2 逆波蘭表示法 105

4.3.3 三地址代碼 107

4.4 表達式及賦值語句的翻譯 110

4.4.1 簡單算術表達式和賦值語句的翻譯 110

4.4.2 布爾表達式的翻譯 111

4.5 控制語句的翻譯 116

4.5.1 條件語句if的翻譯 116

4.5.2 條件循環語句while的翻譯 118

4.5.3 三種基本控制結構的翻譯 119

4.5.4 多分支控制語句case的翻譯 124

4.5.5 語句標號和轉移語句的翻譯 126

4.6 數組元素的翻譯 126

4.6.1 數組元素的地址計算及中間代碼形式 127

4.6.2 賦值語句中數組元素的翻譯 127

4.6.3 數組元素翻譯示例 128

4.7 過程或函式調用語句的翻譯 131

4.7.1 過程或函式調用的方法 131

4.7.2 過程或函式調用語句的四元式生成 132

4.8 說明語句的翻譯 133

4.8.1 變數說明的翻譯 133

4.8.2 數組說明的翻譯 134

4.9 遞歸下降語法制導翻譯方法簡介 134

習題四 136

第五章 代碼最佳化 139

5.1 局部最佳化 139

5.1.1 基本塊的劃分方法 139

5.1.2 基本塊的DAG方法 140

5.1.3 用DAG進行基本塊的最佳化處理 144

5.1.4 DAG構造算法的進一步討論 145

5.2 循環最佳化 146

5.2.1 程式流圖與循環 146

5.2.2 循環的查找 148

5.2.3 循環最佳化 152

*5.3 全局最佳化概述 160

5.3.1 到達-定值與引用-定值鏈 160

5.3.2 定值-引用鏈(du鏈) 164

5.3.3 寫傳播 167

*5.4 代碼最佳化示例 170

習題五 173

第六章 目標程式運行時存儲空間的組織 177

6.1 靜態存儲分配 177

6.2 簡單的棧式存儲分配 178

6.2.1 棧式存儲分配與活動記錄 179

6.2.2 過程的執行 181

6.3 嵌套過程語言的棧式實現 183

6.3.1 嵌套層次顯示(DISPLAY)表和活動記錄 183

6.3.2 嵌套過程的執行 184

6.3.3 訪問非局部名的另一種實現方法 185

6.4 堆式動態存儲分配 189

6.4.1 堆式存儲的概念 189

6.4.2 堆式存儲的管理方法 189

*6.5 參數傳遞補遺 191

6.5.1 參數傳遞的方法 191

6.5.2 不同參數傳遞方法比較 192

習題六 194

第七章 目標代碼生成 196

7.1 簡單代碼生成器 196

7.1.1 待用信息與活躍信息 197

7.1.2 代碼生成算法 199

7.1.3 暫存器分配 200

7.1.4 源程式到目標代碼生成示例 202

*7.2 彙編指令到機器代碼翻譯概述 204

習題七 210

第八章 符號表與錯誤處理 212

8.1 符號表 212

8.1.1 符號表的作用 212

8.1.2 符號表的組織 213

8.1.3 分程式結構語言符號表建立 214

8.1.4 非分程式結構語言符號表建立 217

8.1.5 常用符號表結構 218

8.1.6 符號表內容 219

8.2 錯誤處理 219

8.2.1 語法錯誤校正 220

8.2.2 語義錯誤校正 226

習題八 227

附錄1 8086/8088指令碼匯總表 229

附錄2 8086/8088指令編碼空間表 234

參考文獻 236

相關詞條

熱門詞條

聯絡我們