❶ c語言編譯器原理小知識
1、char *p="asdf"; 則sizeof(p)=2; 是返回指針p佔用位元組數;即使你是先定義再賦值,char *p; p="asdfasdf"; sizeof(p)都是等於2;任何指針在turbo c中都是2個位元組,不是說「字元串中有'0\'佔一個位元組,字元類型指針佔一個位元組」。。樓上有的說sizeof(p)是求變數p或字元串長度,是錯的,是求佔用位元組數,不是長度,長度是用函數strlen(p); sizeof不是函數,是一種運算符。。例子:char p[]="abc";則sizeof(p)=4;strlen(p)=3; 比較於char p[10]="abc"; sizeof(p)=10; strlen(p)=3。。。 但如果定義成:char p[]="asdf"; 則sizeof(p);就等於5了,數組名p雖然可以看做指針,但不完全跟指針一樣,這就是例子了。。 2、編譯器可以看作一個虛擬機器,可以有自己虛擬的內存,棧等。。編譯系統就可以看作是物理電腦操作系統上虛擬機的運行系統。。所以不一定是物理地址,但跟物理地址有映射關系,至於為什麼,怎麼映射,我也不知道。。。 3、編譯器是16位。。跟「loat 為4個位元組 double 32個字元」??。。跟float 4位元組32位沒關系,那是編譯器設定的,就是常說電腦是16位或32位操作系統一樣,編譯器16位就看作虛擬機器是16位運行系統。。 4、 我也不知道為什麼, (*p)(int,int);是int (*p)(int,int);吧。。。
❷ c語言編譯器是用什麼於語言寫的
第一個C語言編譯器應該是用匯編寫的,但是第一個成熟的C語言編譯器應該是由匯編和C語言共同寫的。
編譯原理講到了「自舉編譯器」。大意就是先用底層語言(應該是匯編)寫一個能運行,但效率極低的C語言編譯器(底層語言不好優化),有了C語言的編譯器以後,就可以用C語言好好寫一個編譯器了,用之前那個運行沒問題,但效率低得編譯器編譯一下,就得到了可以使用的編譯器了。
❸ 如何編譯並運行C語言程序
1、創建一個文件名為main.c,然後用任意一個款你熟悉的文本編輯軟體,比如說記事本,在裡面輸入下面的代碼,記住,要用文本文件編輯軟體,不能用word的。

(3)c編譯器擴展原理擴展閱讀:
c語言小游戲實現原理
1、二維數組實現棋盤
二維數組,用兩個for 循環,隨便輸出一個固定符號做棋盤,如 *
2、判定玩家
設計一個計步變數step, 每走一步 step++, 則玩家=step%2+1;
3、判定輸贏(重點)
設計方向數組 dircX[4] ,dircY[4],因為如果要判斷是否練成五子,只有1豎著2橫著3斜下4斜上
豎著的話就是 x-1,y不變
橫著的話就是x不變,y+1; 斜下: x+1,y+1; 斜上 x-1;y+1
這樣你就可以賦值dircX={-1,0,1,-1} dercY={0,1,1,1}
每當玩家落下一子,就全局判斷每個子的四個方向有沒有第二子,如果有,循環判斷有沒有第三子(利用 x+=dircX[1]),直到五子完成,結束。
❹ C語言工作原理
作為一種編程語言,本身是談不上工作原理的,實際上C語言所有的語法,正是C語言編譯器的工作原理或者工作機制的具體實現。要細致的討論起來是不可能,但是作為C語言程序員,必須了解這個大致的流程。一個程序,從C語言源碼,到系統可執行的文件,一般經歷四個過程。
1、預處理階斷,這個階斷是文本處理階斷,有預處理器來完成,會將源碼中的帶"#"開頭的預處理命令進行相應的處理,在linux上C語言的預處理器程序是cp命令。
2、編譯階斷,這個階斷是有C語言編譯階斷,在Linux上C語言的編譯器是cc命令,它將C語言源碼轉換成匯編指令。
3、匯編階斷,這個階斷是匯編編譯階斷,在Linux上C語言的匯編器是as命令,這個階斷會將匯編指令編譯成二進制機器碼。
4、鏈接階斷,這個階斷是會將匯編階斷生成的機器碼目標文件,裝載成一個系統可執行的文件,在Linux平台以ELF格式進行組裝,在Windows平台上以PE格式進行組裝。在Linux平台上的鏈接器命令為ld,在windows平台上的鏈接器命令為linker。
❺ C語言中編譯程序和連接程序的作用和原理是什麼關鍵是原理,越詳細越好,謝了~
詳細了你也不一定能理解,你對底層的了解程度如何?
簡單的來說編譯就是生成語言無關的obj文件,連接就是將所有的obj文件連接起來,查找裡面的符號按照COFF文件的標准生成dll或EXE。
❻ C語言編譯器是用來做什麼的
編譯器,是將便於人編寫,閱讀,維護的高階計算機語言翻譯為計算機能解讀、運行的低階機器語言的程序。編譯器將原始程序(Source program)作為輸入,翻譯產生使用目標語言(Target language)的等價程序。源代碼一般為高階語言 (High-level language), 如 Pascal、C++、Java 等,而目標語言則是匯編語言或目標機器的目標代碼(Object code),有時也稱作機器代碼(Machine code)。
一個現代編譯器的主要工作流程如下:
源代碼 (source code) → 預處理器 (preprocessor) → 編譯器 (compiler) → 匯編程序 (assembler) → 目標代碼 (object code) → 連接器 (Linker) → 可執行程序 (executables)
❼ linux下c語言編譯器的工作原理是怎麼樣的/
c語言編譯器的工作原理都差不多的。一般來說分為四個階斷;
1、預處理階斷,主要是文本替換操作。有預處理器完成。
2、編譯階斷,將C源碼生成匯編代碼,這個是有C語言編譯器來完成的,默認linux下是cc。
3、匯編階斷,將匯編代碼,生成相應的可執行體,即二進制文件。
這個過程都可以自己通過給gcc加入參數來詳細的獲取這些過程的,具體可以參考:http://jingyan..com/article/03b2f78c1d6ede5ea237aed7.html
❽ c語言編譯器是用什麼於語言寫的
第一個C語言編譯器應該是用匯編寫的,但是第一個成熟的C語言編譯器應該是由匯編和C語言共同寫的。
編譯原理講到了「自舉編譯器」。大意就是先用底層語言(應該是匯編)寫一個能運行,但效率極低的C語言編譯器(底層語言不好優化),有了C語言的編譯器以後,就可以用C語言好好寫一個編譯器了,用之前那個運行沒問題,但效率低得編譯器編譯一下,就得到了可以使用的編譯器了。