亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Golang編譯器介紹

發布時間:2020-08-21 16:32:12 來源:腳本之家 閱讀:160 作者:Mvdan 欄目:編程語言

cmd/compile 包含構成 Go 編譯器主要的包。編譯器在邏輯上可以被分為四個階段,我們將簡要介紹這幾個階段以及包含相應代碼的包的列表。
在談到編譯器時,有時可能會聽到 前端(front-end)和 后端(back-end)這兩個術語。粗略地說,這些對應于我們將在此列出的前兩個和后兩個階段。第三個術語 中間端(middle-end)通常指的是第二階段執行的大部分工作。
請注意,go/parser 和 go/types 等 go/* 系列的包與編譯器無關。由于編譯器最初是用 C 編寫的,所以這些 go/* 包被開發出來以便于能夠寫出和 Go 代碼一起工作的工具,例如 gofmt 和 vet。
需要澄清的是,名稱 “gc” 代表 “ Go 編譯器(Go compiler)”,與大寫 GC 無關,后者代表 垃圾收集(garbage collection)。

1、解析

  • cmd/compile/internal/syntax( 詞法分析器(lexer)、 解析器(parser)、 語法樹(syntax tree))

在編譯的第一階段,源代碼被標記化(詞法分析)、解析(語法分析),并為每個源文件構造語法樹(譯注:這里標記指 token,它是一組預定義的、能夠識別的字符串,通常由名字和值構成,其中名字一般是詞法的類別,如標識符、關鍵字、分隔符、操作符、文字和注釋等;語法樹,以及下文提到的 抽象語法樹(Abstract Syntax Tree)(AST),是指用樹來表達程序設計語言的語法結構,通常葉子節點是操作數,其它節點是操作碼)。
每個語法樹都是相應源文件的確切表示,其中節點對應于源文件的各種元素,例如表達式、聲明和語句。語法樹還包括位置信息,用于錯誤報告和創建調試信息。

2、類型檢查和 AST 變換

  • cmd/compile/internal/gc(創建編譯器 AST, 類型檢查(type-checking), AST 變換(AST transformation))

gc 包中包含一個繼承自(早期)C 語言實現的版本的 AST 定義。所有代碼都是基于它編寫的,所以 gc 包必須做的第一件事就是將 syntax 包(定義)的語法樹轉換為編譯器的 AST 表示法。這個額外步驟可能會在將來重構。
然后對 AST 進行類型檢查。第一步是名字解析和類型推斷,它們確定哪個對象屬于哪個標識符,以及每個表達式具有的類型。類型檢查包括特定的額外檢查,例如“聲明但未使用”以及確定函數是否會終止。
特定變換也基于 AST 完成。一些節點被基于類型信息而細化,例如把字符串加法從算術加法的節點類型中拆分出來。其它一些例子是 死代碼消除(dead code elimination), 函數調用內聯(function call inlining)和 逃逸分析(escape analysis)(譯注:逃逸分析是一種分析指針有效范圍的方法)。

3、通用 SSA

  • cmd/compile/internal/gc(轉換成 SSA)
  • cmd/compile/internal/ssa(SSA 相關的 環節(pass)和規則)

(譯注:許多常見高級語言的編譯器無法通過一次掃描源代碼或 AST 就完成所有編譯工作,取而代之的做法是多次掃描,每次完成一部分工作,并將輸出結果作為下次掃描的輸入,直到最終產生目標代碼。這里每次掃描稱作一個 環節(pass);最后一個環節之前所有的環節得到的結果都可稱作中間表示法,本文中 AST、SSA 等都屬于中間表示法。SSA,靜態單賦值形式,是中間表示法的一種性質,它要求每個變量只被賦值一次且在使用前被定義)。
在此階段,AST 將被轉換為 靜態單賦值(Static Single Assignment)(SSA)形式,這是一種具有特定屬性的低級 中間表示法(intermediate representation),可以更輕松地實現優化并最終從它生成機器碼。
在這個轉換過程中,將完成 內置函數(function intrinsics)的處理。這些是特殊的函數,編譯器被告知逐個分析這些函數并決定是否用深度優化的代碼替換它們(譯注:內置函數指由語言本身定義的函數,通常編譯器的處理方式是使用相應實現函數的指令序列代替對函數的調用指令,有點類似內聯函數)。
在 AST 轉化成 SSA 的過程中,特定節點也被低級化為更簡單的組件,以便于剩余的編譯階段可以基于它們工作。例如,內建的拷貝被替換為內存移動,range 循環被改寫為 for 循環。由于歷史原因,目前這里面有些在轉化到 SSA 之前發生,但長期計劃則是把它們都移到這里(轉化 SSA)。
然后,一系列機器無關的規則和編譯環節會被執行。這些并不考慮特定計算機體系結構,因此對所有 GOARCH 變量的值都會運行。
這類通用的編譯環節的一些例子包括,死代碼消除、移除不必要的空值檢查,以及移除無用的分支等。通用改寫規則主要考慮表達式,例如將一些表達式替換為常量,優化乘法和浮點操作。

4、生成機器碼

  • cmd/compile/internal/ssa(SSA 低級化和架構特定的環節)
  • cmd/internal/obj(機器碼生成)

編譯器中機器相關的階段開始于“低級”的編譯環節,該階段將通用變量改寫為它們的特定的機器碼形式。例如,在 amd64 架構中操作數可以在內存中操作,這樣許多 加載-存儲(load-store)操作就可以被合并。
注意低級的編譯環節運行所有機器特定的重寫規則,因此當前它也應用了大量優化。
一旦 SSA 被“低級化”并且更具體地針對目標體系結構,就要運行最終代碼優化的編譯環節了。這包含了另外一個死代碼消除的環節,它將變量移動到更靠近它們使用的地方,移除從來沒有被讀過的局部變量,以及 寄存器(register)分配。
本步驟中完成的其它重要工作包括 堆棧布局(stack frame layout),它將堆棧偏移位置分配給局部變量,以及 指針活性分析(pointer liveness analysis),后者計算每個垃圾收集安全點上的哪些堆棧上的指針仍然是活動的。
在 SSA 生成階段結束時,Go 函數已被轉換為一系列 obj.Prog 指令。它們被傳遞給匯編程序(cmd/internal/obj),后者將它們轉換為機器碼并輸出最終的目標文件。目標文件還將包含反射數據,導出數據和調試信息。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對億速云的支持。如果你想了解更多相關內容請查看下面相關鏈接

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

乃东县| 鄂尔多斯市| 巢湖市| 峨山| 九台市| 长子县| 鄂托克前旗| 宜兰市| 东兴市| 土默特左旗| 玛沁县| 云浮市| 阿勒泰市| 德安县| 宁阳县| 镇康县| 乌拉特后旗| 巫山县| 满城县| 渑池县| 稻城县| 桐梓县| 勐海县| 剑河县| 嘉黎县| 来宾市| 小金县| 灵山县| 汝城县| 微山县| 门头沟区| 平顺县| 蒙自县| 高清| 柳江县| 临汾市| 犍为县| 翁牛特旗| 镇远县| 定州市| 余干县|