• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 297,  comments - 15,  trackbacks - 0
            編譯器,是將便于我們編寫,閱讀,維護(hù)的高級計算機語言翻譯為計算機能識別,運行的低級機器語言的程序。編譯器將源程序(Source program)作為輸入,翻譯產(chǎn)生使用目標(biāo)語言(Target language)的等價程序。源程序一般為高級語言(High-level language),如PascalC++等,而目標(biāo)語言則是匯編語言或目標(biāo)機器的目標(biāo)代碼(Object code),有時也稱作機器代碼(Machine code)。

            一個現(xiàn)代編譯器的主要工作流程如下:
            源程序(source code)→預(yù)處理器(preprocessor)→編譯器(compiler)→匯編程序(assembler)→目標(biāo)程序(object code)→連接器(鏈接器,Linker)→可執(zhí)行程序(executables
             
            工作原理
             
            翻 譯是從源代碼(通常為高級語言)到能直接被計算機或虛擬機執(zhí)行的目標(biāo)代碼(通常為低級語言或機器言)。然而,也存在從低級語言到高級語言的編譯器,這類編 譯器中用來從由高級語言生成的低級語言代碼重新生成高級語言代碼的又被叫做反編譯器。也有從一種高級語言生成另一種高級語言的編譯器,或者生成一種需要進(jìn) 一步處理的的中間代碼的編譯器(又叫級聯(lián))。

             
            典型的編譯器輸出是由包含入口點的名字和地址以及外部調(diào)用的機器代碼所組成的目標(biāo)文件。一組目標(biāo)文件,不必是同一編譯器產(chǎn)生,但使用的編譯器必需采用同樣的輸出格式,可以鏈接在一起并生成可以由用戶直接執(zhí)行的可執(zhí)行程序。

            編譯器種類
             
            編 譯器可以生成用來在與編譯器本身所在的計算機和操作系統(tǒng)(平臺)相同的環(huán)境下運行的目標(biāo)代碼,這種編譯器又叫做“本地”編譯器。另外,編譯器也可以生成用 來在其它平臺上運行的目標(biāo)代碼,這種編譯器又叫做交叉編譯器。交叉編譯器在生成新的硬件平臺時非常有用。“源碼到源碼編譯器”是指用一種高級語言作為輸 入,輸出也是高級語言的編譯器。例如: 自動并行化編譯器經(jīng)常采用一種高級語言作為輸入,轉(zhuǎn)換其中的代碼,并用并行代碼注釋對它進(jìn)行注釋(如OpenMP)或者用語言構(gòu)造進(jìn)行注釋(如FORTRANDOALL指令)。

            預(yù)處理器(preprocessor
             
            作用是通過代入預(yù)定義等程序段將源程序補充完整。

            編譯器前端(frontend
             
            前端主要負(fù)責(zé)解析(parse)輸入的源程序,由詞法分析器和語法分析器協(xié)同工作。詞法分析器負(fù)責(zé)把源程序中的‘單詞’(Token)找出來,語法分析器把這些分散的單詞按預(yù)先定義好的語法組裝成有意義的表達(dá)式,語句,函數(shù)等等。例如“a = b + c;”前端詞法分析器看到的是“a, =, b , +, c;”,語法分析器按定義的語法,先把他們組裝成表達(dá)式“b + c”,再組裝成“a = b + c”的語句。前端還負(fù)責(zé)語義(semantic checking)的檢查,例如檢測參與運算的變量是否是同一類型的,簡單的錯誤處理。最終的結(jié)果常常是一個抽象的語法樹(abstract syntax tree,或 AST),這樣后端可以在此基礎(chǔ)上進(jìn)一步優(yōu)化,處理。

            編譯器后端(backend
             
            編譯器后端主要負(fù)責(zé)分析,優(yōu)化中間代碼(Intermediate representation)以及生成機器代碼(Code Generation)。

             
            一般說來所有的編譯器分析,優(yōu)化,變型都可以分成兩大類:函數(shù)內(nèi)(intraprocedural)還是函數(shù)之間(interprocedural)進(jìn)行。很明顯,函數(shù)間的分析,優(yōu)化更準(zhǔn)確,但需要更長的時間來完成。

             
            編譯器分析(compiler analysis)的對象是前端生成并傳遞過來的中間代碼,現(xiàn)代的優(yōu)化型編譯器(optimizing compiler)常常用好幾種層次的中間代碼來表示程序,高層的中間代碼(high level IR)接近輸入的源程序的格式,與輸入語言相關(guān)(language dependent),包含更多的全局性的信息,和源程序的結(jié)構(gòu);中層的中間代碼(middle level IR)與輸入語言無關(guān),低層的中間代碼(Low level IR)與機器語言類似。不同的分析,優(yōu)化發(fā)生在最適合的那一層中間代碼上。

             
            常見的編譯分析有函數(shù)調(diào)用樹(call tree),控制流程圖(Control flow graph),以及在此基礎(chǔ)上的變量定義-使用,使用-定義鏈(define-use/use-define or u-d/d-u chain),變量別名分析(alias analysis),指針分析(pointer analysis),數(shù)據(jù)依賴分析(data dependence analysis)等等。

             
            上述的程序分析結(jié)果是編譯器優(yōu)化(compiler optimization)和程序變形(compiler transformation)的前提條件。常見的優(yōu)化和變新有:函數(shù)內(nèi)嵌(inlining),無用代碼刪除(Dead code elimination),標(biāo)準(zhǔn)化循環(huán)結(jié)構(gòu)(loop normalization),循環(huán)體展開(loop unrolling),循環(huán)體合并,分裂(loop fusionloop fission),數(shù)組填充(array padding),等等。優(yōu)化和變形的目的是減少代碼的長度,提高內(nèi)存(memory),緩存(cache)的使用率,減少讀寫磁盤,訪問網(wǎng)絡(luò)數(shù)據(jù)的頻率。更高級的優(yōu)化甚至可以把序列化的代碼(serial code)變成并行運算,多線程的代碼(parallelizedmulti-threaded code)。

             
            機器代碼的生成是優(yōu)化變型后的中間代碼轉(zhuǎn)換成機器指令的過程。現(xiàn)代編譯器主要采用生成匯編代碼(assembly code)的策略,而不直接生成二進(jìn)制的目標(biāo)代碼(binary object code)。即使在代碼生成階段,高級編譯器仍然要做很多分析,優(yōu)化,變形的工作。例如如何分配寄存器(register allocatioin),如何選擇合適的機器指令(instruction selection),如何合并幾句代碼成一句等等。


            編譯語言與解釋語言對比
             
            許多人將高級程序語言分為兩類: 編譯型語言解釋型語言。然而,實際上,這些語言中的大多數(shù)既可用編譯型實現(xiàn)也可用解釋型實現(xiàn),分類實際上反映的是那種語言常見的實現(xiàn)方式。(但是,某些解釋型語言,很難用編譯型實現(xiàn)。比如那些允許在線代碼更改的解釋型語言。)
            posted on 2008-07-21 08:57 chatler 閱讀(197) 評論(0)  編輯 收藏 引用 所屬分類: Compiling Theorem

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            <2008年7月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            常用鏈接

            留言簿(10)

            隨筆分類(307)

            隨筆檔案(297)

            algorithm

            Books_Free_Online

            C++

            database

            Linux

            Linux shell

            linux socket

            misce

            • cloudward
            • 感覺這個博客還是不錯,雖然做的東西和我不大相關(guān),覺得看看還是有好處的

            network

            OSS

            • Google Android
            • Android is a software stack for mobile devices that includes an operating system, middleware and key applications. This early look at the Android SDK provides the tools and APIs necessary to begin developing applications on the Android platform using the Java programming language.
            • os161 file list

            overall

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            91久久九九无码成人网站| 国产精品久久久久jk制服| 亚洲成色999久久网站| 久久久女人与动物群交毛片| 久久久久av无码免费网| 亚洲欧洲久久久精品| 久久亚洲国产成人精品无码区| 久久香蕉一级毛片| 久久久精品一区二区三区| 国产成人精品久久二区二区| 韩国三级大全久久网站| 久久久久综合网久久| 久久99国产精品久久久| 996久久国产精品线观看| 国产成人久久精品激情| 精品无码久久久久国产| 国产V综合V亚洲欧美久久| 99久久人妻无码精品系列蜜桃| 99久久无码一区人妻a黑| 久久99国产精品99久久| 国产精品欧美久久久久无广告| 99久久精品国产毛片| 久久国产高清一区二区三区| 欧洲国产伦久久久久久久| 亚洲人成网站999久久久综合| 久久综合久久综合亚洲| 久久精品国产亚洲AV不卡| 新狼窝色AV性久久久久久| 久久香综合精品久久伊人| 久久91亚洲人成电影网站| AA级片免费看视频久久| 午夜精品久久久久久| 无码人妻久久一区二区三区| 国产精品久久久久影视不卡 | 亚洲中文字幕伊人久久无码| 久久精品中文字幕大胸| 久久精品蜜芽亚洲国产AV| 久久夜色tv网站| 久久这里有精品视频| 人妻无码αv中文字幕久久琪琪布| 国产一区二区三区久久|