關(guān)于我們
書(shū)單推薦
新書(shū)推薦
|
自制編譯器
本書(shū)將帶領(lǐng)讀者從頭開(kāi)始制作一門(mén)語(yǔ)言的編譯器。筆者特意為本書(shū)設(shè)計(jì)了C?語(yǔ)言,C?可以說(shuō)是C語(yǔ)言的子集,實(shí)現(xiàn)了包括指針運(yùn)算等在內(nèi)的C語(yǔ)言的主要部分。本書(shū)所實(shí)現(xiàn)的編譯器就是C?語(yǔ)言的編譯器, 是實(shí)實(shí)在在的編譯器,而非有諸多限制的玩具。另外,除編譯器之外,本書(shū)對(duì)以編譯器為中心的編程語(yǔ)言的運(yùn)行環(huán)境,即編譯器、匯編器、鏈接器、硬件、運(yùn)行時(shí)環(huán)境等都有所提及,介紹了程序運(yùn)行的所有環(huán)節(jié)。
貫穿編譯、匯編、鏈接、加載的全過(guò)程!
比“龍書(shū)”更具實(shí)踐性! 1.實(shí)戰(zhàn) 通過(guò)實(shí)際動(dòng)手制作一個(gè)精簡(jiǎn)版C語(yǔ)言編譯器,讓讀者深入了解C語(yǔ)言程序編譯、運(yùn)行背后的細(xì)節(jié)。 2.全面 不僅限于編譯器,對(duì)以編譯器為中心的編程語(yǔ)言的運(yùn)行環(huán)境,即編譯器、匯編器、鏈接器、硬件以及運(yùn)行時(shí)環(huán)境等,均有所涉及。 3.杰出 日本知名技術(shù)書(shū)作家青木峰郎耗時(shí)3年精心打造,通過(guò)具體的例子講解概念,通俗易懂,更適合入門(mén)。
青木峰郎(作者)
程序員,著有《Ruby程序設(shè)計(jì)268技(第2版)》《Ruby源代碼完全解說(shuō)》《Linux程序設(shè)計(jì)》等多部編程相關(guān)著作,并積極參與標(biāo)準(zhǔn)庫(kù)維護(hù)、文檔維護(hù)等各種各樣的活動(dòng)。 嚴(yán)圣逸(譯者) 畢業(yè)于上海交通大學(xué)。8年軟件開(kāi)發(fā)經(jīng)驗(yàn),期間赴日本工作,F(xiàn)就職于想能信息科技(上海)有限公司,從事基于云平臺(tái)的客戶關(guān)系管理及各類(lèi)營(yíng)銷(xiāo)自動(dòng)化系統(tǒng)的開(kāi)發(fā)工作。譯有《高效團(tuán)隊(duì)開(kāi)發(fā):工具與方法》。 絕云(譯者) 畢業(yè)于清華大學(xué)軟件學(xué)院。曾在日本創(chuàng)意公司KAYAC從事即時(shí)通信軟件及社交游戲的開(kāi)發(fā)工作,現(xiàn)任螞蟻金服前端架構(gòu)專(zhuān)家。譯有《寫(xiě)給大家看的算法書(shū)》等圖書(shū),曾參與《像外行一樣思考,像專(zhuān)家一樣實(shí)踐(修訂版)》的審校。
第1章
開(kāi)始制作編譯器 1 1.1 本書(shū)的概要 2 本書(shū)的主題 2 本書(shū)制作的編譯器 2 編譯示例 2 可執(zhí)行文件 3 編譯 4 程序運(yùn)行環(huán)境 6 1.2 編譯過(guò)程 8 編譯的4個(gè)階段 8 語(yǔ)法分析 8 語(yǔ)義分析 9 生成中間代碼 9 代碼生成 10 優(yōu)化 10 總結(jié) 10 1.3 使用C?編譯器進(jìn)行編譯 11 C?編譯器的必要環(huán)境 11 安裝C?編譯器 11 C?的Hello, World! 12 第2章 C?和cbc 13 2.1 C?語(yǔ)言的概要 14 C?的Hello, World! 14 C?中刪減的功能 14 import關(guān)鍵字 15 導(dǎo)入文件的規(guī)范 16 2.2 C?編譯器cbc的構(gòu)成 17 cbc的代碼樹(shù) 17 cbc的包 18 compiler包中的類(lèi)群 18 main函數(shù)的實(shí)現(xiàn) 19 commandMain函數(shù)的實(shí)現(xiàn) 19 Java5泛型 20 build函數(shù)的實(shí)現(xiàn) 20 Java 5的foreach語(yǔ)句 21 compile函數(shù)的實(shí)現(xiàn) 21 第1部分 代碼分析 第3章 語(yǔ)法分析的概要 24 3.1 語(yǔ)法分析的方法 25 代碼分析中的問(wèn)題點(diǎn) 25 代碼分析的一般規(guī)律 25 詞法分析、語(yǔ)法分析、語(yǔ)義分析 25 掃描器的動(dòng)作 26 單詞的種類(lèi)和語(yǔ)義值 27 token 28 抽象語(yǔ)法樹(shù)和節(jié)點(diǎn) 29 3.2 解析器生成器 30 什么是解析器生成器 30 解析器生成器的種類(lèi) 30 解析器生成器的選擇 31 3.3 JavaCC的概要 33 什么是JavaCC 33 語(yǔ)法描述文件 33 語(yǔ)法描述文件的例子 34 運(yùn)行JavaCC 35 啟動(dòng)JavaCC所生成的解析器 36 中文的處理 37 第4章 詞法分析 39 4.1 基于JavaCC的掃描器的描述 40 本章的目的 40 JavaCC的正則表達(dá)式 40 固定字符串 41 連接 41 字符組 41 排除型字符組 41 重復(fù)1次或多次 42 重復(fù)0次或多次 42 重復(fù)n次到m次 42 正好重復(fù)n次 43 可以省略 43 選擇 43 4.2 掃描沒(méi)有結(jié)構(gòu)的單詞 44 TOKEN命令 44 掃描標(biāo)識(shí)符和保留字 44 選擇匹配規(guī)則 45 掃描數(shù)值 46 4.3 掃描不生成token的單詞 48 SKIP命令和SPECIAL_TOKEN命令 48 跳過(guò)空白符 48 跳過(guò)行注釋 49 4.4 掃描具有結(jié)構(gòu)的單詞 50 最長(zhǎng)匹配原則和它的問(wèn)題 50 基于狀態(tài)遷移的掃描 50 MORE命令 51 跳過(guò)塊注釋 52 掃描字符串字面量 53 掃描字符字面量 53 第5章 基于JavaCC的解析器的描述 55 5.1 基于EBNF語(yǔ)法的描述 56 本章的目的 56 基于JavaCC的語(yǔ)法描述 56 終端符和非終端符 57 JavaCC的EBNF表示法 58 連接 58 重復(fù)0次或多次 59 重復(fù)1次或多次 59 選擇 60 可以省略 60 5.2 語(yǔ)法的二義性和token的超前掃描 61 語(yǔ)法的二義性 61 JavaCC的局限性 62 提取左側(cè)共通部分 63 token的超前掃描 63 可以省略的規(guī)則和沖突 64 重復(fù)和沖突 65 更靈活的超前掃描 66 超前掃描的相關(guān)注意事項(xiàng) 66 第6章 語(yǔ)法分析 68 6.1 定義的分析 69 表示程序整體的符號(hào) 69 語(yǔ)法的單位 69 import聲明的語(yǔ)法 70 各類(lèi)定義的語(yǔ)法 71 變量定義的語(yǔ)法 72 函數(shù)定義的語(yǔ)法 73 結(jié)構(gòu)體定義和聯(lián)合體定義的語(yǔ)法 74 結(jié)構(gòu)體成員和聯(lián)合體成員的語(yǔ)法 75 typedef語(yǔ)句的語(yǔ)法 76 類(lèi)型的語(yǔ)法 76 C語(yǔ)言和C?在變量定義上的區(qū)別 77 基本類(lèi)型的語(yǔ)法 77 6.2 語(yǔ)句的分析 79 語(yǔ)句的語(yǔ)法 79 if語(yǔ)句的語(yǔ)法 80 省略if語(yǔ)句和大括號(hào) 80 while語(yǔ)句的語(yǔ)法 81 for語(yǔ)句的語(yǔ)法 81 各類(lèi)跳轉(zhuǎn)語(yǔ)句的語(yǔ)法 82 6.3 表達(dá)式的分析 83 表達(dá)式的整體結(jié)構(gòu) 83 expr的規(guī)則 83 條件表達(dá)式 84 二元運(yùn)算符 85 6.4 項(xiàng)的分析 88 項(xiàng)的規(guī)則 88 前置運(yùn)算符的規(guī)則 88 后置運(yùn)算符的規(guī)則 89 字面量的規(guī)則 89 第2部分 抽象語(yǔ)法樹(shù)和中間代碼 第7章 JavaCC的action和抽象語(yǔ)法樹(shù) 92 7.1 JavaCC的action 93 本章的目的 93 簡(jiǎn)單的action 93 執(zhí)行action的時(shí)間點(diǎn) 93 返回語(yǔ)義值的action 95 獲取終端符號(hào)的語(yǔ)義值 95 Token類(lèi)的屬性 96 獲取非終端符號(hào)的語(yǔ)義值 98 語(yǔ)法樹(shù)的結(jié)構(gòu) 99 選擇和action 99 重復(fù)和action 100 本節(jié)總結(jié) 102 7.2 抽象語(yǔ)法樹(shù)和節(jié)點(diǎn) 103 Node類(lèi)群 103 Node類(lèi)的定義 105 抽象語(yǔ)法樹(shù)的表示 105 基于節(jié)點(diǎn)表示表達(dá)式的例子 107 第8章 抽象語(yǔ)法樹(shù)的生成 110 8.1 表達(dá)式的抽象語(yǔ)法樹(shù) 111 字面量的抽象語(yǔ)法樹(shù) 111 類(lèi)型的表示 112 為什么需要TypeRef類(lèi) 113 一元運(yùn)算的抽象語(yǔ)法樹(shù) 114 二元運(yùn)算的抽象語(yǔ)法樹(shù) 116 條件表達(dá)式的抽象語(yǔ)法樹(shù) 117 賦值表達(dá)式的抽象語(yǔ)法樹(shù) 118 8.2 語(yǔ)句的抽象語(yǔ)法樹(shù) 121 if語(yǔ)句的抽象語(yǔ)法樹(shù) 121 while語(yǔ)句的抽象語(yǔ)法樹(shù) 122 程序塊的抽象語(yǔ)法樹(shù) 123 8.3 聲明的抽象語(yǔ)法樹(shù) 125 變量聲明列表的抽象語(yǔ)法樹(shù) 125 函數(shù)定義的抽象語(yǔ)法樹(shù) 126 表示聲明列表的抽象語(yǔ)法樹(shù) 127 表示程序整體的抽象語(yǔ)法樹(shù) 128 外部符號(hào)的import 128 總結(jié) 129 8.4 cbc 的解析器的啟動(dòng) 132 Parser對(duì)象的生成 132 文件的解析 133 解析器的啟動(dòng) 134 第9章 語(yǔ)義分析(1)引用的消解 135 9.1 語(yǔ)義分析的概要 136 本章目的 136 抽象語(yǔ)法樹(shù)的遍歷 137 不使用Visitor模式的抽象語(yǔ)法樹(shù)的處理 137 基于Visitor模式的抽象語(yǔ)法樹(shù)的處理 138 Vistor模式的一般化 140 cbc中Visitor模式的實(shí)現(xiàn) 141 語(yǔ)義分析相關(guān)的cbc的類(lèi) 142 9.2 變量引用的消解 144 問(wèn)題概要 144 實(shí)現(xiàn)的概要 144 Scope樹(shù)的結(jié)構(gòu) 145 LocalResolver類(lèi)的屬性 146 LocalResolver類(lèi)的啟動(dòng) 146 變量定義的添加 147 函數(shù)定義的處理 148 pushScope方法 149 currentScope方法 149 popScope方法 150 添加臨時(shí)作用域 150 建立VariableNode和變量定義的關(guān)聯(lián) 151 從作用域樹(shù)取得變量定義 151 9.3 類(lèi)型名稱(chēng)的消解 153 問(wèn)題概要 153 實(shí)現(xiàn)的概要 153 TypeResolver類(lèi)的屬性 153 TypeResolver類(lèi)的啟動(dòng) 154 類(lèi)型的聲明 154 類(lèi)型和抽象語(yǔ)法樹(shù)的遍歷 155 變量定義的類(lèi)型消解 156 函數(shù)定義的類(lèi)型消解 157 第10章 語(yǔ)義分析(2)靜態(tài)類(lèi)型檢查 159 10.1 類(lèi)型定義的檢查 160 問(wèn)題概要 160 實(shí)現(xiàn)的概要 161 檢測(cè)有向圖中的閉環(huán)的算法 162 結(jié)構(gòu)體、聯(lián)合體的循環(huán)定義檢查 163 10.2 表達(dá)式的有效性檢查 165 問(wèn)題概要 165 實(shí)現(xiàn)的概要 165 DereferenceChecker類(lèi)的啟動(dòng) 166 SemanticError異常的捕獲 167 非指針類(lèi)型取值操作的檢查 167 獲取非左值表達(dá)式地址的檢查 168 隱式的指針生成 169 10.3 靜態(tài)類(lèi)型檢查 170 問(wèn)題概要 170 實(shí)現(xiàn)的概要 170 C?中操作數(shù)的類(lèi)型 171 隱式類(lèi)型轉(zhuǎn)換 172 TyperChecker類(lèi)的啟動(dòng) 173 二元運(yùn)算符的類(lèi)型檢查 174 隱式類(lèi)型轉(zhuǎn)換的實(shí)現(xiàn) 175 第11章 中間代碼的轉(zhuǎn)換 178 11.1 cbc的中間代碼 179 組成中間代碼的類(lèi) 180 中間代碼節(jié)點(diǎn)類(lèi)的屬性 181 中間代碼的運(yùn)算符和類(lèi)型 182 各類(lèi)中間代碼 183 中間代碼的意義 184 11.2 IRGenerator類(lèi)的概要 185 抽象語(yǔ)法樹(shù)的遍歷和返回值 185 IRGenerator類(lèi)的啟動(dòng) 185 函數(shù)本體的轉(zhuǎn)換 186 作為語(yǔ)句的表達(dá)式的判別 187 11.3 流程控制語(yǔ)句的轉(zhuǎn)換 189 if語(yǔ)句的轉(zhuǎn)換(1)概要 189 if語(yǔ)句的轉(zhuǎn)換(2)沒(méi)有else部分的情況 190 if語(yǔ)句的轉(zhuǎn)換(3)存在else部分的情況 191 while語(yǔ)句的轉(zhuǎn)換 191 break語(yǔ)句的轉(zhuǎn)換(1)問(wèn)題的定義 192 break語(yǔ)句的轉(zhuǎn)換(2)實(shí)現(xiàn)的方針 193 break語(yǔ)句的轉(zhuǎn)換(3)實(shí)現(xiàn) 194 11.4 沒(méi)有副作用的表達(dá)式的轉(zhuǎn)換 196 UnaryOpNode對(duì)象的轉(zhuǎn)換 196 BinaryOpNode對(duì)象的轉(zhuǎn)換 197 指針加減運(yùn)算的轉(zhuǎn)換 198 11.5 左值的轉(zhuǎn)換 200 左邊和右邊 200 左值和右值 200 cbc中左值的表現(xiàn) 201 結(jié)構(gòu)體成員的偏移 202 成員引用(expr.memb)的轉(zhuǎn)換 203 左值轉(zhuǎn)換的例外:數(shù)組和函數(shù) 204 成員引用的表達(dá)式(ptr->memb)的轉(zhuǎn)換 205 11.6 存在副作用的表達(dá)式的轉(zhuǎn)換 206 表達(dá)式的副作用 206 有副作用的表達(dá)式的轉(zhuǎn)換方針 206 簡(jiǎn)單賦值表達(dá)式的轉(zhuǎn)換(1)語(yǔ)句 207 臨時(shí)變量的引入 208 簡(jiǎn)單賦值表達(dá)式的轉(zhuǎn)換(2)表達(dá)式 209 后置自增的轉(zhuǎn)換 210 第3部分 匯編代碼 第12章 x86架構(gòu)的概要 214 12.1 計(jì)算機(jī)的系統(tǒng)結(jié)構(gòu) 215 CPU和存儲(chǔ)器 215 寄存器 215 地址 216 物理地址和虛擬地址 216 各類(lèi)設(shè)備 217 緩存 218 12.2 x86系列CPU的歷史 220 x86系列CPU 220 32位CPU 220 指令集 221 IA-32的變遷 222 IA-32的64位擴(kuò)展——AMD64 222 12.3 IA-32的概要 224 IA-32的寄存器 224 通用寄存器 225 機(jī)器!226 機(jī)器棧的操作 227 機(jī)器棧的用途 227 棧幀 228 指令指針 229 標(biāo)志寄存器 229 12.4 數(shù)據(jù)的表現(xiàn)形式和格式 231 無(wú)符號(hào)整數(shù)的表現(xiàn)形式 231 有符號(hào)整數(shù)的表現(xiàn)形式 231 負(fù)整數(shù)的表現(xiàn)形式和二進(jìn)制補(bǔ)碼 232 字節(jié)序 233 對(duì)齊 233 結(jié)構(gòu)體的表現(xiàn)形式 234 第13章 x86匯編器編程 236 13.1 基于GNU匯編器的編程 237 GNU匯編器 237 匯編語(yǔ)言的Hello, World! 237 基于GNU匯編器的匯編代碼 238 13.2 GNU匯編器的語(yǔ)法 240 匯編版的Hello, World! 240 指令 241 匯編偽操作 241 標(biāo)簽 241 注釋 242 助記符后綴 242 各種各樣的操作數(shù) 243 間接內(nèi)存引用 244 x86指令集的概要 245 13.3 傳輸指令 246 mov指令 246 push指令和pop指令 247 lea指令 248 movsx指令和movzx指令 249 符號(hào)擴(kuò)展和零擴(kuò)展 250 13.4 算術(shù)運(yùn)算指令 251 add指令 251 進(jìn)位標(biāo)志 252 sub指令 252 imul指令 252 idiv指令和div指令 253 inc指令 254 dec指令 255 neg指令 255 13.5 位運(yùn)算指令 256 and指令 256 or指令 257 xor指令 257 not指令 257 sal指令 258 sar指令 258 shr指令 259 13.6 流程的控制 260 jmp指令 260 條件跳轉(zhuǎn)指令(jz、jnz、je、jne、……) 261 cmp指令 262 test指令 263 標(biāo)志位獲取指令(SETcc) 263 call指令 264 ret指令 265 第14章 函數(shù)和變量 266 14.1 程序調(diào)用約定 267 什么是程序調(diào)用約定 267 Linux/x86下的程序調(diào)用約定 267 14.2 Linux/x86下的函數(shù)調(diào)用 269 到函數(shù)調(diào)用完成為止 269 到函數(shù)開(kāi)始執(zhí)行為止 270 到返回原處理流程為止 271 到清理操作完成為止 271 函數(shù)調(diào)用總結(jié) 272 14.3 Linux/x86下函數(shù)調(diào)用的細(xì)節(jié) 274 寄存器的保存和復(fù)原 274 caller-save寄存器和callee-save寄存器 274 caller-save寄存器和callee-save寄存器的靈活應(yīng)用 275 大數(shù)值和浮點(diǎn)數(shù)的返回方法 276 其他平臺(tái)的程序調(diào)用約定 277 第15章 編譯表達(dá)式和語(yǔ)句 278 15.1 確認(rèn)編譯結(jié)果 279 利用cbc進(jìn)行確認(rèn)的方法 279 利用gcc進(jìn)行確認(rèn)的方法 280 15.2 x86匯編的對(duì)象與DSL 282 表示匯編的類(lèi) 282 表示匯編對(duì)象 283 15.3 cbc的x86匯編DSL 285 利用DSL生成匯編對(duì)象 285 表示寄存器 286 表示立即數(shù)和內(nèi)存引用 287 表示指令 287 表示匯編偽操作、標(biāo)簽和注釋 288 15.4 CodeGenerator類(lèi)的概要 290 CodeGenerator類(lèi)的字段 290 CodeGenerator類(lèi)的處理概述 290 實(shí)現(xiàn)compileStmts方法 291 cbc的編譯策略 292 15.5 編譯單純的表達(dá)式 294 編譯Int節(jié)點(diǎn) 294 編譯Str節(jié)點(diǎn) 294 編譯Uni節(jié)點(diǎn)(1)按位取反 295 編譯Uni節(jié)點(diǎn)(2)邏輯非 297 15.6 編譯二元運(yùn)算 298 編譯Bin節(jié)點(diǎn) 298 實(shí)現(xiàn)compileBinaryOp方法 299 實(shí)現(xiàn)除法和余數(shù) 300 實(shí)現(xiàn)比較運(yùn)算 300 15.7 引用變量和賦值 301 編譯Var節(jié)點(diǎn) 301 編譯Addr節(jié)點(diǎn) 302 編譯Mem節(jié)點(diǎn) 303 編譯Assign節(jié)點(diǎn) 303 15.8 編譯jump語(yǔ)句 305 編譯LabelStmt節(jié)點(diǎn) 305 編譯Jump節(jié)點(diǎn) 305 編譯CJump節(jié)點(diǎn) 305 編譯Call節(jié)點(diǎn) 306 編譯Return節(jié)點(diǎn) 307 第16章 分配棧幀 308 16.1 操作!309 cbc中的棧幀 309 棧指針操作原則 310 函數(shù)體編譯順序 310 16.2 參數(shù)和局部變量的內(nèi)存分配 312 本節(jié)概述 312 參數(shù)的內(nèi)存分配 312 局部變量的內(nèi)存分配:原則 313 局部變量的內(nèi)存分配 314 處理作用域內(nèi)的局部變量 315 對(duì)齊的計(jì)算 316 子作用域變量的內(nèi)存分配 316 16.3 利用虛擬棧分配臨時(shí)變量 318 虛擬棧的作用 318 虛擬棧的接口 319 虛擬棧的結(jié)構(gòu) 319 virtualPush方法的實(shí)現(xiàn) 320 VirtualStack#extend方法的實(shí)現(xiàn) 320 VirtualStack#top方法的實(shí)現(xiàn) 321 virtualPop方法的實(shí)現(xiàn) 321 VirtualStack#rewind方法的實(shí)現(xiàn) 321 虛擬棧的運(yùn)作 322 16.4 調(diào)整棧訪問(wèn)的偏移量 323 本節(jié)概要 323 StackFrameInfo類(lèi) 323 計(jì)算正在使用的callee-save寄存器 324 計(jì)算臨時(shí)變量區(qū)域的大小 325 調(diào)整局部變量的偏移量 325 調(diào)整臨時(shí)變量的偏移量 326 16.5 生成函數(shù)序言和尾聲 327 本節(jié)概要 327 生成函數(shù)序言 327 生成函數(shù)尾聲 328 16.6 alloca函數(shù)的實(shí)現(xiàn) 330 什么是alloca函數(shù) 330 實(shí)現(xiàn)原則 330 alloca函數(shù)的影響 331 alloca函數(shù)的實(shí)現(xiàn) 331 第17章 優(yōu)化的方法 333 17.1 什么是優(yōu)化 334 各種各樣的優(yōu)化 334 優(yōu)化的案例 334 常量折疊 334 代數(shù)簡(jiǎn)化 335 降低運(yùn)算強(qiáng)度 335 削除共同子表達(dá)式 335 消除無(wú)效語(yǔ)句 336 函數(shù)內(nèi)聯(lián) 336 17.2 優(yōu)化的分類(lèi) 337 基于方法的優(yōu)化分類(lèi) 337 基于作用范圍的優(yōu)化分類(lèi) 337 基于作用階段的優(yōu)化分類(lèi) 338 17.3 cbc中的優(yōu)化 339 cbc中的優(yōu)化原則 339 cbc中實(shí)現(xiàn)的優(yōu)化 339 cbc中優(yōu)化的實(shí)現(xiàn) 339 17.4 更深層的優(yōu)化 341 基于模式匹配選擇指令 341 分配寄存器 342 控制流分析 342 大規(guī)模的數(shù)據(jù)流分析和SSA形式 342 總結(jié) 343 第4部分 鏈接和加載 第18章 生成目標(biāo)文件 346 18.1 ELF文件的結(jié)構(gòu) 347 ELF的目的 347 ELF的節(jié)和段 348 目標(biāo)文件的主要ELF節(jié) 348 使用readelf命令輸出節(jié)頭 349 使用readelf命令輸出程序頭 350 使用readelf命令輸出符號(hào)表 351 readelf命令的選項(xiàng) 351 什么是DWARF格式 352 18.2 全局變量及其在ELF文件中的表示 354 分配給任意ELF節(jié) 354 分配給通用ELF節(jié) 354 分配.bss節(jié) 355 通用符號(hào) 355 記錄全局變量對(duì)應(yīng)的符號(hào) 357 記錄符號(hào)的附加信息 357 記錄通用符號(hào)的附加信息 358 總結(jié) 358 18.3 編譯全局變量 360 generate方法的實(shí)現(xiàn) 360 generateAssemblyCode方法的實(shí)現(xiàn) 360 編譯全局變量 361 編譯立即數(shù) 362 編譯通用符號(hào) 363 編譯字符串字面量 364 生成函數(shù)頭 365 計(jì)算函數(shù)的代碼大小 366 總結(jié) 366 18.4 生成目標(biāo)文件 367 as命令調(diào)用的概要 367 引用GNUAssembler類(lèi) 367 調(diào)用as命令 367 第19章 鏈接和庫(kù) 369 19.1 鏈接的概要 370 鏈接的執(zhí)行示例 370 gcc和GNU ld 371 鏈接器處理的文件 372 常用庫(kù) 374 鏈接器的輸入和輸出 374 19.2 什么是鏈接 375 鏈接時(shí)進(jìn)行的處理 375 合并節(jié) 375 重定位 376 符號(hào)消解 377 19.3 動(dòng)態(tài)鏈接和靜態(tài)鏈接 379 兩種鏈接方法 379 動(dòng)態(tài)鏈接的優(yōu)點(diǎn) 379 動(dòng)態(tài)鏈接的缺點(diǎn) 380 動(dòng)態(tài)鏈接示例 380 靜態(tài)鏈接示例 381 庫(kù)的檢索規(guī)則 381 19.4 生成庫(kù) 383 生成靜態(tài)庫(kù) 383 Linux中共享庫(kù)的管理 383 生成共享庫(kù) 384 鏈接生成的共享庫(kù) 385 第20章 加載程序 387 20.1 加載ELF段 388 利用mmap系統(tǒng)調(diào)用進(jìn)行文件映射 388 進(jìn)程的內(nèi)存鏡像 389 內(nèi)存空間的屬性 390 ELF段對(duì)應(yīng)的內(nèi)存空間 390 和ELF文件不對(duì)應(yīng)的內(nèi)存空間 392 ELF文件加載的實(shí)現(xiàn) 393 20.2 動(dòng)態(tài)鏈接過(guò)程 395 動(dòng)態(tài)鏈接加載器 395 程序從啟動(dòng)到終止的過(guò)程 395 啟動(dòng)ld.so 396 系統(tǒng)內(nèi)核傳遞的信息 397 AUX矢量 397 讀入共享庫(kù) 398 符號(hào)消解和重定位 399 運(yùn)行初始化代碼 400 執(zhí)行主程序 401 執(zhí)行終止處理 402 ld.so解析的環(huán)境變量 402 20.3 動(dòng)態(tài)加載 404 所謂動(dòng)態(tài)加載 404 Linux下的動(dòng)態(tài)加載 404 動(dòng)態(tài)加載的架構(gòu) 405 20.4 GNU ld的鏈接 406 用于cbc的ld選項(xiàng)的結(jié)構(gòu) 406 C運(yùn)行時(shí) 407 生成可執(zhí)行文件 408 生成共享庫(kù) 408 第21章 生成地址無(wú)關(guān)代碼 410 21.1 地址無(wú)關(guān)代碼 411 什么是地址無(wú)關(guān)代碼 411 全局偏移表(GOT) 412 獲取GOT地址 412 使用GOT地址訪問(wèn)全局變量 413 訪問(wèn)使用GOT地址的文件內(nèi)部的全局變量 414 過(guò)程鏈接表(PLT) 414 調(diào)用PLT入口 416 地址無(wú)關(guān)的可執(zhí)行文件:PIE 416 21.2 全局變量引用的實(shí)現(xiàn) 418 獲取GOT地址 418 PICThunk函數(shù)的實(shí)現(xiàn) 418 刪除重復(fù)函數(shù)并設(shè)置不可見(jiàn)屬性 419 加載GOT地址 420 locateSymbols函數(shù)的實(shí)現(xiàn) 421 全局變量的引用 421 訪問(wèn)全局變量:地址無(wú)關(guān)代碼的情況下 422 函數(shù)的符號(hào) 423 字符串常量的引用 424 21.3 鏈接器調(diào)用的實(shí)現(xiàn) 425 生成可執(zhí)行文件 425 generateSharedLibrary方法 426 21.4 從程序解析到執(zhí)行 428 build和加載的過(guò)程 428 詞法分析 429 語(yǔ)法分析 429 生成中間代碼 430 生成代碼 431 匯編 432 生成共享庫(kù) 432 生成可執(zhí)行文件 433 加載 433 第22章 擴(kuò)展閱讀 434 22.1 參考書(shū)推薦 435 編譯器相關(guān) 435 語(yǔ)法分析相關(guān) 435 匯編語(yǔ)言相關(guān) 436 22.2 鏈接、加載相關(guān) 437 22.3 各種編程語(yǔ)言的功能 438 異常封裝相關(guān)的圖書(shū) 438 垃圾回收 438 垃圾回收相關(guān)的圖書(shū) 439 面向?qū)ο缶幊陶Z(yǔ)言的實(shí)現(xiàn) 439 函數(shù)式語(yǔ)言 440 附 錄 441 A.1 參考文獻(xiàn) 442 A.2 在線資料 444 A.3 源代碼 445
你還可能感興趣
我要評(píng)論
|