LLVM和GCC的區(qū)別

GCC: GNU Compiler Collection
GCC屬于傳統(tǒng)編譯器火惊,傳統(tǒng)編譯器的工作原理基本上都是三段式的,可以分為前端(Frontend)卧抗、優(yōu)化器(Optimizer)读跷、后端(Backend)。前端負(fù)責(zé)解析源代碼唤崭,檢查語法錯誤拷恨,并將其翻譯為抽象的語法樹(Abstract Syntax Tree)。優(yōu)化器對這一中間代碼進(jìn)行優(yōu)化谢肾,試圖使代碼更高效腕侄。后端則負(fù)責(zé)將優(yōu)化器優(yōu)化后的中間代碼轉(zhuǎn)換為目標(biāo)機(jī)器的代碼,這一過程后端會最大化的利用目標(biāo)機(jī)器的特殊指令芦疏,以提高代碼的性能冕杠。
事實上,不光靜態(tài)語言如此酸茴,動態(tài)語言也符合上面這個模型分预,例如Java。Java Virtual Machine也利用上面這個模型薪捍,將Java代碼翻譯為Java bytecode笼痹。這一模型的好處是配喳,當(dāng)我們要支持多種語言時,只需要添加多個前端就可以了凳干。當(dāng)需要支持多種目標(biāo)機(jī)器時晴裹,只需要添加多個后端就可以了。對于中間的優(yōu)化器救赐,我們可以使用通用的中間代碼涧团。
這種三段式的結(jié)構(gòu)還有一個好處,開發(fā)前端的人只需要知道如何將源代碼轉(zhuǎn)換為優(yōu)化器能夠理解的中間代碼就可以了经磅,他不需要知道優(yōu)化器的工作原理泌绣,也不需要了解目標(biāo)機(jī)器的知識。這大大降低了編譯器的開發(fā)難度预厌,使更多的開發(fā)人員可以參與進(jìn)來阿迈。
雖然這種三段式的編譯器有很多有點,并且被寫到了教科書上配乓,但是在實際中這一結(jié)構(gòu)卻從來沒有被完美實現(xiàn)過仿滔。做的比較好的應(yīng)該屬Java和.NET虛擬機(jī)。虛擬機(jī)可以將目標(biāo)語言翻譯為bytecode犹芹,所以理論上講我們可以將任何語言翻譯為bytecode崎页,然后輸入虛擬機(jī)中運行。但是這一動態(tài)語言的模型并不太適合C語言腰埂,所以硬將C語言翻譯為bytecode并實現(xiàn)垃圾回收機(jī)制的效率是非常低的飒焦。
GCC也將三段式做的比較好,并且實現(xiàn)了很多前端屿笼,支持了很多語言牺荠。但是上述這些編譯器的致命缺陷是,他們是一個完整的可執(zhí)行文件驴一,沒有給其它語言的開發(fā)者提供代碼重用的接口休雌。即使GCC是開源的,但是源代碼重用的難度也比較大肝断。

LLVM: Low Level Virtual Machine
LLVM最初是[Low Level Virtual Machine]的縮寫杈曲,定位是一個虛擬機(jī),但是是比較底層的虛擬機(jī)胸懈。它的出現(xiàn)正是為了解決編譯器代碼重用的問題担扑,LLVM一上來就站在比較高的角度,制定了LLVM IR這一中間代碼表示語言趣钱。LLVM IR充分考慮了各種應(yīng)用場景涌献,例如在IDE中調(diào)用LLVM進(jìn)行實時的代碼語法檢查,對靜態(tài)語言首有、動態(tài)語言的編譯燕垃、優(yōu)化等枢劝。
LLVM與GCC在三段式架構(gòu)上并沒有本質(zhì)區(qū)別。LLVM與其它編譯器最大的差別是卜壕,它不僅僅是Compiler Collection呈野,也是Libraries Collection。舉個例子印叁,假如說我要寫一個XYZ語言的優(yōu)化器,我自己實現(xiàn)了PassXYZ算法军掂,用以處理XYZ語言與其它語言差別最大的地方轮蜕。而LLVM優(yōu)化器提供的PassA和PassB算法則提供了XYZ語言與其它語言共性的優(yōu)化算法。那么我可以選擇XYZ優(yōu)化器在鏈接的時候把LLVM提供的算法鏈接進(jìn)來蝗锥。LLVM不僅僅是編譯器跃洛,也是一個SDK。
Clang錯誤提示比GCC友好得多终议。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末汇竭,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子穴张,更是在濱河造成了極大的恐慌细燎,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,284評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件皂甘,死亡現(xiàn)場離奇詭異玻驻,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)偿枕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評論 3 395
  • 文/潘曉璐 我一進(jìn)店門璧瞬,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人渐夸,你說我怎么就攤上這事嗤锉。” “怎么了墓塌?”我有些...
    開封第一講書人閱讀 164,614評論 0 354
  • 文/不壞的土叔 我叫張陵瘟忱,是天一觀的道長。 經(jīng)常有香客問我桃纯,道長酷誓,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,671評論 1 293
  • 正文 為了忘掉前任态坦,我火速辦了婚禮盐数,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘伞梯。我一直安慰自己玫氢,他們只是感情好帚屉,可當(dāng)我...
    茶點故事閱讀 67,699評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著漾峡,像睡著了一般攻旦。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上生逸,一...
    開封第一講書人閱讀 51,562評論 1 305
  • 那天牢屋,我揣著相機(jī)與錄音,去河邊找鬼槽袄。 笑死烙无,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的遍尺。 我是一名探鬼主播截酷,決...
    沈念sama閱讀 40,309評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼乾戏!你這毒婦竟也來了迂苛?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,223評論 0 276
  • 序言:老撾萬榮一對情侶失蹤鼓择,失蹤者是張志新(化名)和其女友劉穎三幻,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體呐能,經(jīng)...
    沈念sama閱讀 45,668評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡赌髓,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,859評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了催跪。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片锁蠕。...
    茶點故事閱讀 39,981評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖懊蒸,靈堂內(nèi)的尸體忽然破棺而出荣倾,到底是詐尸還是另有隱情,我是刑警寧澤骑丸,帶...
    沈念sama閱讀 35,705評論 5 347
  • 正文 年R本政府宣布舌仍,位于F島的核電站,受9級特大地震影響通危,放射性物質(zhì)發(fā)生泄漏铸豁。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,310評論 3 330
  • 文/蒙蒙 一菊碟、第九天 我趴在偏房一處隱蔽的房頂上張望节芥。 院中可真熱鬧,春花似錦、人聲如沸头镊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽相艇。三九已至颖杏,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間坛芽,已是汗流浹背留储。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留咙轩,地道東北人欲鹏。 一個月前我還...
    沈念sama閱讀 48,146評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像臭墨,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子膘盖,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,933評論 2 355

推薦閱讀更多精彩內(nèi)容