精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Go 1.3+ 編譯器變革

開發 前端
“gc"Go工具鏈來自Plan 9編譯器的工具鏈。組裝器、C編譯器和鏈接器基本沒變。Go的編譯器(cmd/gc,cmd/5g,cmd/6g,cmd/8g)是配合工具鏈寫的新的C程序。

概述

目前Go編譯器是C寫的,是時候換成Go啦。

背景

“gc"Go工具鏈來自Plan 9編譯器的工具鏈。組裝器、C編譯器和鏈接器基本沒變。Go的編譯器(cmd/gc,cmd/5g,cmd/6g,cmd/8g)是配合工具鏈寫的新的C程序。

項目起始時,用C而不是Go寫編譯器有很多好處。突出的比如,首先,那時候Go還不存在,沒法兒寫編譯器。而且實際上,就算存在,也會經常有明顯的不兼容的變化。用C不用Go可以避免初始和持續開發導致的問題。然而如今Go 1已經穩定,所以這些持續的問題減少了很多。

持續開發的問題已經消除,為了讓Go實現的編譯器比C更有吸引力,另一些工程問題出現:

  • 寫正確的Go代碼比寫正確的C代碼更容易。
  • 調試錯誤的Go代碼比調試錯誤的C代碼更容易。
  • 使用Go編譯器需要對Go有一定理解。而用C編譯器還需要一定理解C。
  • Go使并發執行比C更方便。
  • Go有更好的標準支持模塊化,自動重寫,單元測試和性能分析。
  • Go比C更有趣(fun)。

基于以上理由,我們相信是時候用Go寫Go編譯器啦。

計劃設想

我們打算用自動化翻譯工具來用Go重寫現在C的編譯器。這個翻譯需要一些階段,將從Go 1.3開始持續到未來的發行版。

第一階段。開發和調試一個自動化翻譯工具。這可以在日常開發時同步進行。而且,人們還可以在這個階段為C編譯器繼續改進。這個工 具工作量很大,不過我們有信心完成這個特殊使命的工具。有許多C的觀念沒法兒直接轉換成Go;macros(宏),unions(聯合,共用 體,),bit fields(位域)可能最先考慮。比較幸運(不是巧合),這些功能功能用的少,都會被翻譯掉。指針運算和數組也需要一些轉換工作,盡管編譯器里很少。編 譯器里主要是tree(樹)和linked list(鏈表)。翻譯工具會保留注釋和C代碼的結構,所以翻譯后的代碼和當前的編譯器代碼一樣可閱讀。

第二階段。用翻譯工具轉換C代碼到Go,并刪除C源碼。這時我們已經開始翻譯,但是Go還是運行在C編譯器上。非常樂觀的,這可能發生在Go 1.3。不過更可能是Go 1.4。

第三階段。使用一些工具,可能來自gofix和the Go oracle,拆分編譯器到包,清理和文檔化代碼,添加適當的單元測試。這是編譯器會是地道的Go程序。目前打算在Go 1.4實現。

第四a階段。使用標準的分析和測試工具優化編譯器的CPU和內存使用。可能要引入并行。如果真這樣,Race Detector(Go的并行競爭檢測工具,)會有很大幫助。這目標在Go 1.4,可能部分會延后到1.5。基本的優化分析會在第三階段完成。

第四b階段。(和四a幾段同時進行)當編譯器依照明顯的界限分割成包之后, 需要明確引入一個中介碼,在結構無關的無序樹(Node*s)和結構相關的有序鏈表(Prog*s)之間。這個中介碼應該不依賴整體架構,但是包含準確的 執行順序信息,可以用于有順序但是結構無關的操作的優化,比如清理多余的nil檢測和出界檢測。這些過程基于SSA(靜態單賦值),你可以從Alan Donovan的 go.tools/ssa 包中了解更多。

第五階段。替換go/parser和go/types到最新(全新)的版本。Robert Griesemer參考現在的經驗,討論了設計新的parser和types的可能。如果聯系他們到編譯器后端,相信對設計新的API有很大幫助。

自展(Bootstrapping)

用Go語言實現的Go的編譯器,從一開始就要考慮如何自展。我們考慮的規則就是Go1.3編譯器必須由Go1.2編譯,Go1.4的編譯器必須由Go1.4編譯,以此類推。

這時,我們就有了一個清晰的流程來生成當前的程序:編譯Go1.2的工具鏈(由C編寫),然后使用它編譯Go1.3的工具鏈,以此類推。這里需要一 個腳本來做這個事情,來保證只會消耗CPU的時間而非某個人的時間。這樣的自展,每個機器只會做一次,Go1.x的工具鏈將會在本地保留,并在執行 all.bash來編譯Go1.(x+1)工具鏈的時候被再次使用。

顯然,隨著時間的推移這種自舉方式是不充分的。在后面的多個版本被發布之前,為編譯器寫一個后端來生成C代碼也許是一個更有意義的事情。這些C代碼 不要求效率或可讀性,只要正確即可。這些C代碼將會被簽入,就像我們簽入由yacc生成的y.tab.c文件一樣。這樣,自展過程就會變成:先用gcc編 譯C代碼生成一個自展編譯器,然后使用這個自展編譯器來編譯真正的編譯器。類似于另一個自展過程,這個自展編譯器將會在本地保留,并在每次執行 all.bash的時候重復使用(不用重新編譯)。

替代選擇

還有一些比較明顯的替代方案,需要我們說明一下為什么放棄了這些選擇。

從一開始寫一個編譯器。現在的編譯器有一個非常重要的特征:他們能夠正常工作(或者其至少能夠滿足所有用戶的要求)。盡管Go語言比較簡單,但是編譯器中有很多細微的細節優化和改寫,直接丟棄10或數年的在這上面的努力是比較愚蠢的。

對編譯器進行人工翻譯。我們已經以人工的方式翻譯了一小部分C/C++代碼到Go語言了。這個過程是枯燥而且易錯的,且這些錯誤非常的細微及難以發 現。相反,使用機械翻譯會形成一些比較一致的錯誤,而這些錯誤是易于發現的;而且不會因為枯燥的過程開小差。Go編譯器的代碼明顯的比我們翻譯的代碼多很 多:超過60,000行C代碼,機械翻譯會使這個過程容易一些。就像Dick Sites在1974年說的一樣:“相比寫程序,我寧愿寫一個程序來幫我寫 程序。“ 使用機械來翻譯編譯器也方便于在準備好切換之前,我們可以繼續開發完善現有的C程序。

只翻譯后端并鏈接到go/parser和go/types.從前端傳給后端的數據結構所包含的 信息中,go/parser和go/types所能提供的除了API就沒其他的東西了。如果使用這些庫來替代前端,需要寫代碼來轉換go/parser和 go/types所能提供數據結構到后端,這是一個非常寬泛且易出錯的工作。我們相信使用這些庫是有意義的,但更明智的是,等到將編譯器代碼調整的更像 Go程序,分成確定邊界的、包含說明文檔和單元測試子包之后再使用。

放棄現有的編譯器,使用gccgo(或者go/parser + go/types + LLVM,  …)。現有的編譯器是Go語言顯得比較靈活的一個重要組成部分。如果嘗試使用基于大量代碼的GCC或LLVM來開發Go程序,感覺會有礙到Go語言的靈 活性。另外,GCC是大量C代碼(現在有部分C++)、LLVM是大量C++代碼的程序。以上列舉的、用于解釋不使用現有編譯框架代碼的幾個原因,也都適 用于更多的類似的代碼庫。

C語言的長期使用

臨近結束,這個計劃還留下了由C寫成的Plan9的工具鏈的一部分。在長期發展中,還是將所有的C從代碼樹排除掉比較好。本章節推測了一下這件事將會如何發生,但不保證其指定會發生或者按照這種套路發生。

運行時包(runtime)。 runtime包的大部分都是用C寫成,基于一些同樣的原因,Go編譯器也是用C實現。但是,runtime包遠比 編譯器的代碼量要小,且它現在已經是用Go和C混合編寫。將C代碼轉換為Go代碼時,一次轉化一部分貌似也是可行的。其中,主要部分有:調度器 (scheduler),垃圾回收(the garbage collector),散列映射表(hash map)的實現,和channel的實現。(這里Go和C代碼混合的很融洽,是因為這里使用的6c而不是gcc來編譯的C代碼。)

C編譯器。 Plan 9的C編譯器本身就是用C寫成,如果我們要從Go包實現里面移除所有的C代碼,那么我們將移除這些編譯工具:“go tool 6c”等等,另外,.c的文件也將不被支持出現的Go包的目錄里面。我們應該提前聲明這樣的計劃,以便使用C的第三方包有時間去移除這類C代碼的使用。 (Cgo,由于使用了gcc來替代6c,所以它仍然可以作為一個途徑來在Go包中使用C實現部分功能。)在Go1的兼容性文檔中沒有包含工具鏈修改的描 述,也就是說去掉C編譯器是被允許的。

 

匯編器。 Plan 9的匯編器也是用C實現的,但這個匯編器只不過是一系列解析樹組成的簡單解析器,這使得不論手動還是自動將它翻譯成Go語言都比較簡單。

連接器。 Plan 9的連接器也是由C寫成。最近的一些工作,已經將大部分的連接器工作放到的編譯器中,而且,也已經有個計劃將剩余的部分重寫成一個新的、更簡單的Go程序。轉移到編譯器的部分連接器代碼,現在需要隨著編譯器的原有代碼一起進行翻譯。

基于Libmach的工具: nm, pack, addr2line, 和objdump。 Nm現在已經使用Go語言重寫。Pack和addr2line可以任何一天被重寫。Objdump現在依賴于libmach的反匯編器,但這些轉換為Go也是比較簡單的,不論是使用機械還是人工翻譯。所以基于這幾點,libmach本身將來也可以被移除。

原文鏈接:https://docs.google.com/document/d/1P3BLR31VA8cvLJLfMibSuTdwTuF7WWLux71CYD0eeD8/preview?sle=true

責任編輯:陳四芳 來源: 開源中國編譯
相關推薦

2021-09-06 07:59:13

Go編譯器語言

2021-08-22 17:18:58

Go代碼泛型代碼

2022-08-22 07:38:01

Go語言函數

2010-01-21 09:11:38

C++編譯器

2010-01-18 10:34:21

C++編譯器

2010-03-23 11:17:16

Python 動態編譯

2017-03-20 18:01:55

編譯器匯編

2009-08-10 17:12:54

C#編譯器

2013-03-29 10:02:37

編譯器語言編譯開發

2021-05-13 18:53:34

Go編譯器Uber

2010-10-20 13:43:37

C++編譯器

2019-08-06 08:20:07

編譯器工具開發者

2009-07-06 12:49:33

JSP編譯器

2010-01-18 10:28:15

C++編譯器

2009-08-14 11:34:26

Mono C#編譯器

2009-08-04 15:52:58

ASP.NET編譯器

2022-05-18 09:31:42

編譯器開源代碼生成

2010-07-29 14:18:57

Flex編譯器參數

2019-11-15 15:20:27

Golang編譯器前端

2013-12-10 10:53:47

shellcode
點贊
收藏

51CTO技術棧公眾號

国产日韩一区| silk一区二区三区精品视频| 国产精品无人区| 91夜夜揉人人捏人人添红杏| 久久网一区二区| 亚洲综合图色| 欧美巨大另类极品videosbest | 六十路在线观看| 免费观看在线综合色| 欧美国产日韩中文字幕在线| 亚洲精品国产一区黑色丝袜| 日韩欧美高清一区二区三区| 色婷婷久久久综合中文字幕| 国产激情在线看| 精品欧美不卡一区二区在线观看 | av电影免费在线观看| 91在线视频在线| 91精品视频在线看| 亚洲欧美一区二区三区在线观看 | 黄页网站大全在线观看| av中文在线| 99re热这里只有精品视频| 成人免费网站在线看| 中文人妻av久久人妻18| 伊人成人在线| 欧美日韩成人网| 99久久久无码国产精品不卡| 亚洲综合图色| 亚洲国产精品久久精品怡红院| 国产又大又黄又猛| 亚洲最大成人| 婷婷综合在线观看| 少妇大叫太大太粗太爽了a片小说| 二区三区在线播放| 国产人成亚洲第一网站在线播放 | 成人福利在线| 26uuu国产电影一区二区| 97久草视频| 国产成人精品一区二区无码呦| 免费看精品久久片| 国产aaa精品| 午夜影院在线看| 伊人成人在线| 97视频在线观看网址| 久草网在线观看| 亚洲电影影音先锋| 美女扒开尿口让男人操亚洲视频网站| 久久精品国产亚洲AV成人婷婷| 蜜桃视频欧美| 亚洲四色影视在线观看| 国产又粗又猛又爽视频| 美女久久99| 亚洲网站视频福利| 亚洲色图 激情小说| 欧美日韩久久精品| 一区二区成人精品| 黄色av片三级三级三级免费看| 波多野结衣一区| 中文字幕一区日韩电影| 青青青手机在线视频| 欧美好骚综合网| 九九热在线精品视频| 特级片在线观看| 亚洲一级电影| 秋霞av国产精品一区| 免费的毛片视频| 另类欧美日韩国产在线| 91精品综合视频| 亚洲精品综合网| 99精品视频在线观看| 久久国产精品免费一区| 国产三级在线观看| 日韩美女啊v在线免费观看| 蜜桃视频成人在线观看| 大香伊人久久| 欧美日韩一区二区免费在线观看 | 国产美女视频一区| 69174成人网| 人人妻人人澡人人爽人人欧美一区| 成人黄色在线看| 欧美日韩精品一区| 欧美成人视屏| 午夜欧美2019年伦理| 成人在线免费播放视频| avtt久久| 日韩av在线不卡| 激情五月深爱五月| 激情视频一区| 国产精品黄色av| 精品国自产拍在线观看| 久久综合网色—综合色88| 亚洲精品一区二区三区樱花| a免费在线观看| 日韩欧美主播在线| 色综合五月婷婷| 亚洲第一福利专区| 久久亚洲欧美日韩精品专区| av资源免费观看| 国产一区二区免费看| 欧美日韩一区二区三区免费| 污视频网站在线免费| 色视频欧美一区二区三区| 久久黄色一级视频| 精品一区二区三区在线| 久久久久久伊人| 91好色先生tv| 久久久久久久av麻豆果冻| 日韩video| 欧美三级精品| 亚洲精品福利在线观看| 国产在线观看免费视频软件| aa级大片欧美三级| 999精品视频一区二区三区| 国产香蕉在线| 欧美小视频在线| 制服丝袜av在线| 亚洲91久久| 国产精品久久久久久久av大片| 日本xxxx人| 亚洲精品国产品国语在线app| 成人在线免费播放视频| 久草精品视频| 欧美激情视频播放| 国产绿帽刺激高潮对白| 国产精品久久久久久久久久免费看| 亚洲不卡中文字幕无码| 一区二区亚洲视频| 久久成年人视频| 一二三四区视频| 国产欧美中文在线| 日本黄网站免费| 亚洲毛片免费看| 97在线视频观看| 亚洲国产剧情在线观看| 玉米视频成人免费看| 九九九九九国产| 国产高清久久| 成人久久精品视频| 麻豆网站在线| 欧美精品一二三区| 国产成人免费在线观看视频| 日本vs亚洲vs韩国一区三区二区 | 在线视频国产区| 666欧美在线视频| tube国产麻豆| 国产成人综合网站| 国产黄色片免费在线观看| 爱高潮www亚洲精品| 久久久久久久久久久网站| 懂色av一区二区三区四区| 亚洲综合一区二区三区| 图片区偷拍区小说区| 在线欧美福利| 精品久久一区二区三区蜜桃| 是的av在线| 亚洲欧洲国产伦综合| 波多野结衣毛片| 国产精品电影一区二区| 欧美一级特黄aaa| 中文字幕日韩一区二区不卡| av蓝导航精品导航| 成人三级小说| 亚洲裸体xxxx| 伊人成人在线观看| 亚洲欧美aⅴ...| 亚洲精品激情视频| 日韩中文字幕91| 午夜啪啪免费视频| jizz久久精品永久免费| 欧美与黑人午夜性猛交久久久| 精品福利视频导航大全| 欧美情侣在线播放| 久久综合综合久久| 久久久影视传媒| 污污动漫在线观看| 欧美午夜精品| 日本不卡一区| 狂野欧美xxxx韩国少妇| 91禁外国网站| 日本在线视频站| 精品国产一区二区国模嫣然| 麻豆传媒一区二区| 国产三级短视频| 久久99精品久久久久久| 激情五月婷婷六月| 精品在线91| 亚洲一区免费网站| 自拍视频在线看| 久久久国产视频91| 日本一本草久在线中文| 制服丝袜亚洲色图| 精品成人av一区二区在线播放| 国产精品久久久久9999吃药| 亚洲少妇一区二区三区| 日本亚洲三级在线| 国产欧美日韩小视频| 色婷婷一区二区三区| 国内精品一区二区| 国产精品麻豆| 国产精品99久久久久久久久| 不卡一本毛片| 日韩色av导航| 国产免费av高清在线| 精品国产精品网麻豆系列| 中文字幕人妻一区二区三区视频| 一区二区三区成人| 精品女人久久久| 久久久国产午夜精品| 中文字幕在线国产| 狠狠狠色丁香婷婷综合激情| 青青视频在线播放| 在线国产精品一区| 国产内射老熟女aaaa| 成人羞羞在线观看网站| 久久综合九色综合久99| 91精品啪在线观看国产手机| 成人免费视频97| 成人午夜sm精品久久久久久久| 91av视频在线| 99riav视频在线观看| 欧美成人精品一区二区三区| 午夜看片在线免费| 国产一区二区动漫| 欧洲天堂在线观看| 精品无码久久久久久国产| 亚洲精品久久久蜜桃动漫 | 成人激情四射网| 91精品在线观看入口| 亚洲最大成人av| 欧美人与禽zozo性伦| 懂色av蜜臀av粉嫩av喷吹| 色综合av在线| 天天干天天色综合| 日韩欧美国产骚| 欧美一区二区三区网站| 欧美日韩午夜激情| 亚洲天堂一区在线观看| 色综合天天综合网国产成人综合天| 国产午夜免费视频| 亚洲www啪成人一区二区麻豆| 久久精品亚洲无码| 午夜精品久久久久久久久| 欧美福利视频一区二区| 偷窥国产亚洲免费视频| 日本一区二区三区精品| 一本色道a无线码一区v| 日韩 国产 欧美| 欧美午夜在线观看| 亚洲视频在线观看一区二区| 欧美日韩免费观看一区三区| 影音先锋黄色网址| 欧美一区二区播放| 欧美一区二区黄片| 亚洲国产精品人人爽夜夜爽| 亚洲av成人精品一区二区三区在线播放| 亚洲高清免费观看高清完整版| 色欲久久久天天天综合网| 亚洲男人天堂网| 91在线播放网站| 久久的精品视频| 色呦呦视频在线观看| 97久久精品人人澡人人爽缅北| 美女网站在线看| 国产成人精品视频在线| 国产亚洲欧美日韩精品一区二区三区 | 国产韩日精品| 91免费看片在线| 国产一区二区三区亚洲| 欧美日韩一区综合| 天天av综合| 免费国产黄色网址| 天堂蜜桃一区二区三区| 午夜天堂在线视频| 成人小视频免费在线观看| 色天使在线视频| 一区二区中文字幕在线| 精品肉丝脚一区二区三区| 色国产综合视频| 99久久99久久久精品棕色圆| 日韩第一页在线| 日本中文字幕伦在线观看| 国内精品久久久久久| 成人免费毛片嘿嘿连载视频…| 91黄在线观看| 欧美综合久久| 久久精品xxx| 日本欧美大码aⅴ在线播放| 三上悠亚 电影| 中文字幕精品在线不卡| 国产精品99精品无码视| 欧美久久久久久久久中文字幕| 熟妇人妻中文av无码| 色黄久久久久久| 黄色aa久久| 96pao国产成视频永久免费| 怕怕欧美视频免费大全| 日韩国产成人无码av毛片| 蜜臀av一级做a爰片久久| 丝袜熟女一区二区三区 | 亚洲精品456在线播放狼人| 在线播放日本| 秋霞午夜一区二区| 国产精东传媒成人av电影| 一区二区不卡在线视频 午夜欧美不卡'| 亚洲国产专区校园欧美| 亚洲天堂一区二区在线观看| 国产亚洲精品精华液| 日本一区二区三区四区五区| 欧美久久一二区| jizzjizz在线观看| 欧美亚洲第一页| 国产精品中文字幕制服诱惑| 在线播放 亚洲| 免费看日韩精品| 中字幕一区二区三区乱码| 婷婷六月综合亚洲| 国产 日韩 欧美 精品| 久久综合免费视频| 日韩欧乱色一区二区三区在线| 欧美在线一区二区三区四区| 在线综合亚洲| bl动漫在线观看| 亚洲一区影音先锋| www.好吊色| 久久这里只有精品99| 99久热在线精品视频观看| 亚洲精品中文综合第一页| 肉丝袜脚交视频一区二区| 黄色a一级视频| 欧美性生活大片免费观看网址| 亚洲精品911| 欧美激情一区二区三级高清视频| 国产一区二区三区免费观看在线| 亚洲精品一区二区三区蜜桃久| 日本中文字幕一区| 免费黄色在线网址| 在线成人高清不卡| 免费a在线看| 亚洲www在线| 欧美三区视频| 扒开伸进免费视频| 精品久久久久久中文字幕大豆网| 三级网站在线看| 欧美性视频网站| 国产精品欧美在线观看| 日日摸天天爽天天爽视频| 久久久精品国产免大香伊| 日本视频一区二区在线观看| caoprom在线| 国产精品美女xx| 亚洲伦理一区| 成都免费高清电影| 欧美日免费三级在线| 在线免费黄色| 3d精品h动漫啪啪一区二区| 中文视频一区| yjizz视频| 色一情一乱一乱一91av| 91免费在线| 97在线资源站| 亚洲一区国产| www.狠狠爱| 7777精品伊人久久久大香线蕉完整版 | 欧美久久久精品| 欧美黄色录像| 中文字幕第80页| 亚洲美女屁股眼交3| 欧美在线精品一区二区三区| 日本久久精品视频| 欧美电影免费| 美女伦理水蜜桃4| 91久久久免费一区二区| 国产淫片在线观看| 精品亚洲一区二区三区四区五区高| 久久一区二区三区超碰国产精品| 男人天堂资源网| 日韩女同互慰一区二区| 亚洲涩涩在线| 正义之心1992免费观看全集完整版| 国产丶欧美丶日本不卡视频| 久久久久久久久久久久久久av| 一区二区三区四区视频| 国产aⅴ精品一区二区四区| 精品无码一区二区三区在线| 欧美国产在线观看| 韩国av永久免费| 国产精品v片在线观看不卡| 午夜影院欧美| aaaaaav| 欧美二区三区的天堂| 免费毛片b在线观看| 在线观看欧美激情| 91小视频在线| 国产成人三级在线播放 | 久久国产精品美女| 女人天堂av手机在线| 亚洲精品综合在线| 91涩漫在线观看| 久久久久久99| 国产成人av自拍|