編譯器的鏈接原理
A. c++ 編譯器 鏈接器 如何運行 原理是什麼
#include "fun.cpp"
這一句使得在編譯的時候fun.cpp全文將被復制到主程序文件中,在主文件裡面當然能使用了,這不是文件作用域的問題。
至於前一個問題,你沒給出程序的全文,我也看不出來。
另外:對樓主的回復:
你對fun.cpp也使用include的話,則fun.cpp中的內容肯定也是要復制過去的,只要你用include。(include這個保留字的含義就是告訴編譯器除了讀包含include這個語句的文件之外還要讀取include語句包含的文件).一般來說,我們在include後麵包含的都是xxxx.h這樣的頭文件,這是因為在頭文件裡麵包含的都是聲明而不是定義,在一個工程中聲明可以重復多次但是定義(不管它在哪個文件裡面定義)只能一次。像樓主這樣包含fun.cpp的話肯定會導致重復定義的(fun.h和fun.cpp編譯之後形成的fun.obj裡面有函數的實現,main.cpp由於把fun.cpp裡面的內容include進來所以裡面也有函數的實現).至於加了static後為什麼對這是因為static保留字限制了其後所定義的函數或變數只能在本文件中使用.
建議樓主把主程序文件中的#include"fun.cpp"改成#include"fun.h"再試試,另外,找本書看看include和static(主要是靜態全局變數而不是靜態局部變數)相關的內容。
對樓主的再次答復:.h和.cpp中包含的東西是不一樣的。一般來說,.h中放置聲明語句(主要是供編譯器進行類型及函數原型檢查),而.cpp中放置數據的定義以及函數的實現等。而#include語句只包含.h文件。這一點我不知道是不是c語言的規定,但是一般來說編程都是這樣做的。
如果不怕困難,建議你去看一本書,linker and loader 中文版+英文版,網址是:http://download.csdn.net/source/331053
B. C語言中編譯程序和連接程序的作用和原理是什麼關鍵是原理,越詳細越好,謝了~
詳細了你也不一定能理解,你對底層的了解程度如何?
簡單的來說編譯就是生成語言無關的obj文件,連接就是將所有的obj文件連接起來,查找裡面的符號按照COFF文件的標准生成dll或EXE。
C. linux下c語言編譯器的工作原理是怎麼樣的/
c語言編譯器的工作原理都差不多的。一般來說分為四個階斷;
1、預處理階斷,主要是文本替換操作。有預處理器完成。
2、編譯階斷,將C源碼生成匯編代碼,這個是有C語言編譯器來完成的,默認linux下是cc。
3、匯編階斷,將匯編代碼,生成相應的可執行體,即二進制文件。
這個過程都可以自己通過給gcc加入參數來詳細的獲取這些過程的,具體可以參考:http://jingyan..com/article/03b2f78c1d6ede5ea237aed7.html
D. 匯編編譯器工作原理
首先這個一一對應的關系是確定的
其次匯編編譯就是簡單對應和少量計算,就是查一個特別大的表而已
具體可以了解一下編譯原理(這是個大坑,慎入)
E. 匯編的編譯器的原理
建議直接從C51學匯編,來的直觀
F. 編譯器有哪幾部分構成.編譯原理
1. 詞法分析
詞法分析器根據詞法規則識別出源程序
中的各個記號(token),每個記號代表一類單詞(lexeme)。源程序中常見的記號可以歸為幾大類:關鍵字、標識符、字面量和特殊符號。詞法分析器
的輸入是源程序,輸出是識別的記號流。詞法分析器的任務是把源文件的字元流轉換成記號流。本質上它查看連續的字元然後把它們識別為「單詞」。
2. 語法分析
語法分析器根據語法規則識別出記號流中的結構(短語、句子),並構造一棵能夠正確反映該結構的語法樹。
3. 語義分析
語義分析器根據語義規則對語法樹中的語法單元進行靜態語義檢查,如果類型檢查和轉換等,其目的在於保證語法正確的結構在語義上也是合法的。
4. 中間代碼生成
中間代碼生成器根據語義分析器的輸出生成中間代碼。中間代碼可以有若干種形式,它們的共同特徵是與具體機器無關。最常用的一種中間代碼是三地址碼,它的一種實現方式是四元式。三地址碼的優點是便於閱讀、便於優化。
G. 交叉編譯器的原理
編譯是從源代碼(通常為高級語言)到能直接被計算機或虛擬機執行的目標代碼(通常為低階語言或機器語言)的翻譯過程。然而,也存在從低階語言到高階語言的編譯器,這類編譯器中用來從由高階語言生成的低階語言代碼重新生成高階語言代碼的又被叫做反編譯器。也有從一種高階語言生成另一種高階語言的編譯器,或者生成一種需要進一步處理的的中間代碼的編譯器(又叫級聯)。
典型的編譯器輸出是由包含入口點的名字和地址, 以及外部調用(到不在這個目標文件中的函數調用)的機器代碼所組成的目標文件。一組目標文件,不必是同一編譯器產生,但使用的編譯器必需採用同樣的輸出格式,可以鏈接在一起並生成可以由用戶直接執行的可執行程序。
H. 編譯器的工作原理
編譯 是從源代碼(通常為高級語言)到能直接被計算機或虛擬機執行的目標代碼(通常為低級語言或機器語言)的翻譯過程。然而,也存在從低級語言到高級語言的編譯器,這類編譯器中用來從由高級語言生成的低級語言代碼重新生成高級語言代碼的又被叫做反編譯器。也有從一種高級語言生成另一種高級語言的編譯器,或者生成一種需要進一步處理的的中間代碼的編譯器(又叫級聯)。
典型的編譯器輸出是由包含入口點的名字和地址, 以及外部調用(到不在這個目標文件中的函數調用)的機器代碼所組成的目標文件。一組目標文件,不必是同一編譯器產生,但使用的編譯器必需採用同樣的輸出格式,可以鏈接在一起並生成可以由用戶直接執行的EXE,
所以我們電腦上的文件都是經過編譯後的文件。
I. 編譯器的工作原理實際上就是自動機嗎
不是。一個完整的編譯器包含詞法分析、語法分析、語義分析、中間代碼生成、目標代碼翻譯和性能優化等諸多步驟。你說的有限自動機是僅用於詞法分析的詞法識別器。
J. 編譯器構造原理
編譯器,是將便於人編寫,閱讀,維護的高級計算機語言翻譯為計算機能識別,運行的低級機器語言的程序。
編譯器將源程序作為輸入,翻譯產生使用目標語言的等價程序。源程序一般為高級語言,如C++等,而目標語言則是匯編語言或目標機器的目標代碼,有時也稱作機器代碼。
一個現代編譯器的主要工作流程如下:
源代碼→預處理器→編譯器→匯編程序→目標代碼→連接器→可執行程序