欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Golang編譯器介紹

 更新時間:2018年09月26日 11:04:36   作者:Mvdan  
今天小編就為大家分享一篇關于go語言編譯器的介紹,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧

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

1、解析

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

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

2、類型檢查和 AST 變換

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

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

3、通用 SSA

  • cmd/compile/internal/gc(轉換成 SSA)
  • cmd/compile/internal/ssa(SSA 相關的 環(huán)節(jié)(pass)和規(guī)則)

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

4、生成機器碼

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

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

總結

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

相關文章

  • Go使用協(xié)程交替打印字符

    Go使用協(xié)程交替打印字符

    這篇文章主要介紹了Go使用協(xié)程交替打印字符,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04
  • Go語言狀態(tài)機的實現(xiàn)

    Go語言狀態(tài)機的實現(xiàn)

    本文主要介紹了Go語言狀態(tài)機的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-03-03
  • Go進行接口組合的解決方案

    Go進行接口組合的解決方案

    在 Go 語言中,接口組合是一種強大的特性,它允許將多個接口組合成一個新的接口,從而提供更靈活和可擴展的代碼設計,本文給大家介紹了Go如何進行接口組合,需要的朋友可以參考下
    2024-06-06
  • Golang自定義結構體轉map的操作

    Golang自定義結構體轉map的操作

    這篇文章主要介紹了Golang自定義結構體轉map的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • Golang設計模式之原型模式詳細講解

    Golang設計模式之原型模式詳細講解

    如果一個類的有非常多的屬性,層級還很深。每次構造起來,不管是直接構造還是用建造者模式,都要對太多屬性進行復制,那么有沒有一種好的方式讓我們創(chuàng)建太的時候使用體驗更好一點呢? 今天的文章里就給大家介紹一種設計模式,來解決這個問題
    2023-01-01
  • Go語言os包用法詳解

    Go語言os包用法詳解

    本文主要介紹了Go語言os包用法詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-04-04
  • golang映射Map的方法步驟

    golang映射Map的方法步驟

    這篇文章主要介紹了golang映射Map的方法步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • go語言阻塞函數(shù)和非阻塞函數(shù)實現(xiàn)

    go語言阻塞函數(shù)和非阻塞函數(shù)實現(xiàn)

    本文主要介紹了go語言阻塞函數(shù)和非阻塞函數(shù)實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-03-03
  • 關于go平滑重啟庫overseer實現(xiàn)原理詳解

    關于go平滑重啟庫overseer實現(xiàn)原理詳解

    這篇文章主要為大家詳細介紹了關于go平滑重啟庫overseer實現(xiàn)原理,文中的示例代碼講解詳細,具有一定的參考價值,有需要的小伙伴可以參考下
    2023-11-11
  • golang interface指針實現(xiàn)示例

    golang interface指針實現(xiàn)示例

    本文主要介紹了golang interface指針實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-08-08

最新評論