新聞中心
深入了解:Linux下C程序編譯的原理和流程

在Linux環(huán)境下,C程序是一種較為常見(jiàn)的程序語(yǔ)言,因此了解其編譯的原理和流程對(duì)于Linux技術(shù)人員來(lái)說(shuō)非常重要。本文將介紹 Linux下C程序編譯的原理和流程的相關(guān)知識(shí)點(diǎn)。
一、編譯器
編譯器是將我們編寫(xiě)的源程序轉(zhuǎn)換為可執(zhí)行文件的工具。在Linux中,常見(jiàn)的編譯器有g(shù)cc和clang。gcc是GNU C Compiler的縮寫(xiě),它是在Linux系統(tǒng)中最常用的編譯器,而clang則是一個(gè)可以替代gcc的編譯器,它具有更好的編譯速度和優(yōu)化效果。
二、編譯的過(guò)程
編譯的過(guò)程分為四個(gè)階段:預(yù)處理、編譯、匯編和鏈接。
預(yù)處理階段:該階段主要用來(lái)處理源文件中的預(yù)處理指令,如#include和#define等。預(yù)處理器將源代碼中出現(xiàn)的特定字符序列進(jìn)行處理,生成新的C源代碼文件,并將其名稱(chēng)以.i作為擴(kuò)展名。
編譯階段:該階段將預(yù)處理后的C源代碼分割成多個(gè)小模塊,每個(gè)小模塊包含一個(gè)函數(shù),一個(gè)類(lèi)或一段代碼段。編譯器將這些小模塊翻譯成匯編語(yǔ)言,然后生成匯編語(yǔ)言文件并以.s為擴(kuò)展名保存。
匯編階段:該階段是將匯編語(yǔ)言文件轉(zhuǎn)換為機(jī)器語(yǔ)言文件。匯編器將匯編語(yǔ)言文件翻譯為二進(jìn)制目標(biāo)文件,并以.o為擴(kuò)展名保存。
鏈接階段:該階段主要是將預(yù)編譯、編譯、匯編階段的多個(gè)目標(biāo)文件鏈接成一個(gè)可執(zhí)行文件。鏈接器將這些目標(biāo)文件中的全局變量、函數(shù)等符號(hào)進(jìn)行統(tǒng)一,然后生成可執(zhí)行文件。
三、Makefile
在Linux下,我們將源程序轉(zhuǎn)換為可執(zhí)行文件時(shí)需要經(jīng)過(guò)多個(gè)工具的處理,這些工具的操作指令相較于我們手動(dòng)敲入,略顯繁瑣。因此,使用Makefile可以幫助我們將多個(gè)指令整合并運(yùn)行,提升了編譯的效率和精度。Makefile是一個(gè)特殊的文件,它提供了一種簡(jiǎn)單的方法來(lái)自動(dòng)化源代碼和可執(zhí)行文件之間的轉(zhuǎn)換過(guò)程。
在Makefile中,我們可以定義源程序、編譯器、鏈接器等信息,然后使用make工具自動(dòng)化執(zhí)行這個(gè)文件的內(nèi)容,從而實(shí)現(xiàn)源程序轉(zhuǎn)換為可執(zhí)行文件的過(guò)程。Makefile在C程序的編譯過(guò)程中扮演了非常重要的角色,形成了一個(gè)自動(dòng)化的編譯過(guò)程。
四、
Linux下C程序編譯的整個(gè)過(guò)程分為預(yù)處理、編譯、匯編和鏈接四個(gè)階段。在實(shí)際編譯過(guò)程中,我們可以使用gcc等編譯器和Makefile來(lái)簡(jiǎn)化編譯過(guò)程,提升編譯效率和精度。了解Linux下C程序編譯的原理和流程對(duì)于Linux技術(shù)人員掌握C程序是非常有幫助的。
相關(guān)問(wèn)題拓展閱讀:
- Linux中,運(yùn)行一個(gè)C語(yǔ)言程序如何運(yùn)行
- 請(qǐng)問(wèn)linux下,gcc編譯程序的過(guò)程(從讀取源文件到制作可執(zhí)行程序中間所有過(guò)程,越詳細(xì)越好)
Linux中,運(yùn)行一個(gè)C語(yǔ)言程序如何運(yùn)行
這個(gè):
網(wǎng)返遲桐旦滑頁(yè)鏈接漏坦
1、打開(kāi)kali linux的終端。創(chuàng)建一個(gè)文件并命名為test.c。在終端輸入:touch test.c。
2、可以看到已經(jīng)生成了一個(gè)后綴為test.c的源文件。然后用vim工具打開(kāi)這個(gè)文件并編寫(xiě)代碼。在終端中輸入:vim test.c或者gvim test.c打開(kāi)這個(gè)文件并編寫(xiě)代碼。
3、編寫(xiě)完了這個(gè)代碼。現(xiàn)在開(kāi)始編譯源文件。在終端中輸入:gcc test.cgcc是linux自帶的c語(yǔ)言編譯器。如果是windows則要用ide工具來(lái)編譯。linux系統(tǒng)一般寫(xiě)C語(yǔ)言用gcc +vim+gdb三個(gè)自帶畝李的工具就可以了。
4、打完gcc test.c編譯完C源文件。然后就可以看見(jiàn)a.out的文件。一般linux系統(tǒng)就默認(rèn)為a.out為編譯完的文件?,F(xiàn)在運(yùn)行a.out文件。在a.out文件的目錄下打開(kāi)終端并迅鍵遲輸入./a.out就是運(yùn)行文件了。
5、如果想要編譯完的文件名不要用a.out文件。就可以在編譯時(shí)打入.gcc test.c -o test.out然后就可以看見(jiàn)有一個(gè)test.out.文件 了。-o后面跟著的編譯生成的文件名。
6、再運(yùn)行test.out在終端亮清中輸入./test.out結(jié)果如圖。這樣在linux系統(tǒng)下編譯并運(yùn)行C語(yǔ)言就完成了。
在Linux中,可以使用gcc編譯器編譯氏槐春C語(yǔ)言程序,生成可執(zhí)行文件,并最終執(zhí)行。
具體步驟如下:
1、編譯。
由.c文件生成.o文件,寫(xiě)作:
gcc a.c -o a.o -c
這個(gè)命令可以將a.c編譯成a.o。
如果存在多個(gè)文件,可殲?zāi)鸵灾饌€(gè)編譯,即a.c b.c… 生成a.o b.o…等。
2、鏈接。
由.o文件生成可執(zhí)行文件,寫(xiě)作:
gcc a.o b.o c.o -o a.out
這個(gè)命令將a.o b.o c.o三個(gè)目標(biāo)文件明缺,生成可執(zhí)行文件a.out。
3、執(zhí)行。
調(diào)用命令:
./a.out
即可執(zhí)行生成的可執(zhí)行文件a.out。
4、注意事項(xiàng):
(1) 當(dāng)文件較少時(shí),可以省略目標(biāo)文件步驟,編譯鏈接一步執(zhí)行,如:
gcc a.c b.c c.c -o a.out
(2) 提供的示例為最基礎(chǔ)的編譯功能,在實(shí)際應(yīng)用中g(shù)cc有很豐富的編譯選項(xiàng),根據(jù)需求進(jìn)行添加。
(3) 當(dāng)項(xiàng)目包含文件較多時(shí),可以使用makefile進(jìn)行管理。
如果已經(jīng)寫(xiě)好了源文件,那么cd 進(jìn)所在的目錄gcc filename.c -o filename;./filename;找到一個(gè)學(xué)習(xí)linux的好方法簡(jiǎn)頃旦,另外你是感興趣的話可以看下劉遄老師寫(xiě)的《Linux就該這么學(xué)》作為入門(mén)的書(shū)籍,覺(jué)乎侍得不錯(cuò)攔擾的話采納下哦~
編譯生成可執(zhí)行文件,然后運(yùn)行即可,沒(méi)什么特殊的呀
請(qǐng)問(wèn)linux下,gcc編譯程序的過(guò)程(從讀取源文件到制作可執(zhí)行程序中間所有過(guò)程,越詳細(xì)越好)
1.gcc -E *.c 預(yù)處理,把宏,頭文件展開(kāi)缺念
2.gcc -S *.c 預(yù)處理+反匯編
3.gcc -c *.c 預(yù)稿坦處理+反匯編+obj文伏敬困件
4.gcc -o *.o 預(yù)處理+反匯編+obj文件+鏈接,生成可執(zhí)行文件
大概就這樣吧,記不住了都
Linux的發(fā)行版中包含了很多軟件開(kāi)發(fā)工具. 它們中的很多是用于 C 和 C++應(yīng)用程
序開(kāi)發(fā)的.
GNU C 編譯器
用 gdb 來(lái)調(diào)試GCC應(yīng)用程序
你也能看到隨 Linux 發(fā)行的其他有用的 C 編程工具. 這些工具包括源程序美
化程序(pretty print programs), 附加的調(diào)試工具, 函數(shù)原型自動(dòng)生成工具
(automatic function prototypers).
GNU C 編譯器
隨 Slackware Linux 發(fā)行的 GNU C 編譯器(GCC)是一個(gè)全功能的 ANSI C 兼
容編譯器. 如果你熟悉其他操作系統(tǒng)或硬件平臺(tái)上的一種 C 編譯器, 你將能很快
地掌握 GCC.
使用 GCC
通常后跟一些選項(xiàng)和文件名來(lái)使用 GCC 編譯器. gcc 命令的基本用法如下:
gcc
命令行選項(xiàng)指定的操作將在命令行上每個(gè)給出的文件上執(zhí)行. 下一小節(jié)將敘述
一些你會(huì)最常用到的選項(xiàng).
GCC 選項(xiàng)
GCC 有超過(guò)100個(gè)的編譯選項(xiàng)可用. 這些選項(xiàng)中的許多你可能永遠(yuǎn)都不會(huì)用到,
但一些主要的選項(xiàng)將會(huì)頻繁用到. 很多的 GCC 選項(xiàng)包括一個(gè)以上的字符. 因此你
必須為每個(gè)選項(xiàng)指定各自的連字符, 并且就象大多數(shù) Linux 命令一樣你不能在一
個(gè)單獨(dú)的連字符后跟一組選項(xiàng). 例如, 下面的兩個(gè)命令是不同的:
gcc -p -g test.c
gcc -pg test.c
之一條命令告訴 GCC 編譯 test.c 時(shí)為 prof 命令建立剖析(profile)信息并
且把調(diào)試信息加入到可執(zhí)行的文件里. 第二條命令只告訴 GCC 為 gprof 命令建立
剖析信息.
當(dāng)你不用任何選項(xiàng)編譯一個(gè)程序時(shí), GCC 將會(huì)建立(假定編譯成功)一個(gè)名為
a.out 的可執(zhí)行文件. 例如, 下面的命令將在當(dāng)前目錄下產(chǎn)生一個(gè)叫 a.out 的文
件:
gcc test.c
你能用 -o 編譯選項(xiàng)來(lái)為將產(chǎn)生的可執(zhí)行文件指定一個(gè)文件名來(lái)代替 a.out.
例如, 將一個(gè)叫 count.c 的 C 程序編譯為名叫 count 的可執(zhí)行文件, 你將輸入
下面的命令:
gcc -o count count.c
—
注意: 當(dāng)你使用 -o 選項(xiàng)時(shí), -o 后面必須跟一個(gè)文件名.
—
GCC 同樣有指定編譯器處理多少的編譯選項(xiàng). -c 選項(xiàng)告訴 GCC 僅把源代碼編
譯為目標(biāo)代碼而跳過(guò)匯編和連接的步驟. 這個(gè)閉掘選項(xiàng)使用的非常頻繁因?yàn)樗沟镁幾g
多個(gè) C 程序時(shí)速度更快并且更謹(jǐn)氏易于管理. 缺省時(shí) GCC 建立的目標(biāo)代碼文件有一個(gè)
.o 的擴(kuò)展名.
-S 編譯選項(xiàng)告訴 GCC 在為 C 代碼產(chǎn)生了匯編語(yǔ)言文件后停止編譯. GCC 產(chǎn)
生的匯編語(yǔ)言文件的缺省擴(kuò)展名是 .s . -E 選項(xiàng)指示編譯器僅對(duì)輸入文件進(jìn)行預(yù)
處理. 當(dāng)這個(gè)選項(xiàng)被使用時(shí), 預(yù)處理器的輸出被送到標(biāo)準(zhǔn)輸出而不是儲(chǔ)存在文件里。
優(yōu) 化 選 項(xiàng)
當(dāng)你用 GCC 編譯 C 代碼時(shí), 它會(huì)試著用最少的時(shí)間完成編譯并且使編譯后的
代碼易于調(diào)試. 易于調(diào)試意味著編譯后的代碼與源代碼有同樣的執(zhí)行次序, 編譯后
的代碼沒(méi)有經(jīng)過(guò)優(yōu)化. 有很多選項(xiàng)可用于告訴 GCC 在耗費(fèi)更多編譯時(shí)間和犧牲易
調(diào)試性的基礎(chǔ)上產(chǎn)生更小更快的可執(zhí)行文件. 這些選項(xiàng)中最典型的是-O 和 -O2 選
項(xiàng).
-O 選項(xiàng)告訴 GCC 對(duì)源代碼進(jìn)行基本優(yōu)化. 這些優(yōu)化在大多數(shù)情況下都會(huì)使程
序執(zhí)行的更快. -O2 選項(xiàng)告訴 GCC 產(chǎn)生盡可能小和盡可能快的代碼. -O2 選項(xiàng)將
使編譯的速度比使用 -O 時(shí)慢. 但通常產(chǎn)生的祥態(tài)散代碼執(zhí)行速度會(huì)更快.
除了 -O 和 -O2 優(yōu)化選項(xiàng)外, 還有一些低級(jí)選項(xiàng)用于產(chǎn)生更快的代碼. 這些
選項(xiàng)非常的特殊, 而且更好只有當(dāng)你完全理解這些選項(xiàng)將會(huì)對(duì)編譯后的代碼產(chǎn)生什
么樣的效果時(shí)再去使用. 這些選項(xiàng)的詳細(xì)描述, 請(qǐng)參考 GCC 的指南頁(yè), 在命令行
上鍵入 man gcc .
調(diào)試和剖析選項(xiàng)
GCC 支持?jǐn)?shù)種調(diào)試和剖析選項(xiàng). 在這些選項(xiàng)里你會(huì)最常用到的是 -g 和 -pg
選項(xiàng).
-g 選項(xiàng)告訴 GCC 產(chǎn)生能被 GNU 調(diào)試器使用的調(diào)試信息以便調(diào)試你的程序.
GCC 提供了一個(gè)很多其他 C 編譯器里沒(méi)有的特性, 在 GCC 里你能使 -g 和 -O (
產(chǎn)生優(yōu)化代碼)聯(lián)用. 這一點(diǎn)非常有用因?yàn)槟隳茉谂c最終產(chǎn)品盡可能相近的情況下
調(diào)試你的代碼. 在你同時(shí)使用這兩個(gè)選項(xiàng)時(shí)你必須清楚你所寫(xiě)的某些代碼已經(jīng)在優(yōu)
化時(shí)被 GCC 作了改動(dòng). 關(guān)于調(diào)試 C 程序的更多信息請(qǐng)看下一節(jié)”用 gdb 調(diào)試 C
程序” .
-pg 選項(xiàng)告訴 GCC 在你的程序里加入額外的代碼, 執(zhí)行時(shí), 產(chǎn)生 gprof 用的
剖析信息以顯示你的程序的耗時(shí)情況. 關(guān)于 gprof 的更多信息請(qǐng)參考 “gprof” 一
節(jié).
用 gdb 調(diào)試 GCC 程序
Linux 包含了一個(gè)叫 gdb 的 GNU 調(diào)試程序. gdb 是一個(gè)用來(lái)調(diào)試 C 和
C++ 程序的強(qiáng)力調(diào)試器. 它使你能在程序運(yùn)行時(shí)觀察程序的內(nèi)部結(jié)構(gòu)和內(nèi)存的使用
情況. 以下是 gdb 所提供的一些功能:
它使你能監(jiān)視你程序中變量的值.
它使你能設(shè)置斷點(diǎn)以使程序在指定的代碼行上停止執(zhí)行.
它使你能一行行的執(zhí)行你的代碼.
在命令行上鍵入 gdb 并按回車(chē)鍵就可以運(yùn)行 gdb 了, 如果一切正常的話,
gdb 將被啟動(dòng)并且你將在屏幕上看到類(lèi)似的內(nèi)容:
GDB is free software and you are welcome to distribute copies of it
under certain conditions; type “show copying” to see the conditions.
There is absolutely no warranty for GDB; type “show warranty” for
details.
GDB 4.14 (i486-slakware-linux), Copyright 1995 Free Software Foundation,
Inc.
(gdb)
當(dāng)你啟動(dòng) gdb 后, 你能在命令行上指定很多的選項(xiàng). 你也可以以下面的方式
來(lái)運(yùn)行 gdb :
gdb
當(dāng)你用這種方式運(yùn)行 gdb , 你能直接指定想要調(diào)試的程序. 這將告訴gdb 裝
入名為 fname 的可執(zhí)行文件. 你也可以用 gdb 去檢查一個(gè)因程序異常終止而產(chǎn)生
的 core 文件, 或者與一個(gè)正在運(yùn)行的程序相連. 你可以參考 gdb 指南頁(yè)或在命
令行上鍵入 gdb -h 得到一個(gè)有關(guān)這些選項(xiàng)的說(shuō)明的簡(jiǎn)單列表.
為調(diào)試編譯代碼(Compiling Code for Debugging)
為了使 gdb 正常工作, 你必須使你的程序在編譯時(shí)包含調(diào)試信息. 調(diào)試信息
包含你程序里的每個(gè)變量的類(lèi)型和在可執(zhí)行文件里的地址映射以及源代碼的行號(hào).
gdb 利用這些信息使源代碼和機(jī)器碼相關(guān)聯(lián).
在編譯時(shí)用 -g 選項(xiàng)打開(kāi)調(diào)試選項(xiàng).
gdb 基本命令
gdb 支持很多的命令使你能實(shí)現(xiàn)不同的功能. 這些命令從簡(jiǎn)單的文件裝入到
允許你檢查所調(diào)用的堆棧內(nèi)容的復(fù)雜命令, 表27.1列出了你在用 gdb 調(diào)試時(shí)會(huì)用
到的一些命令. 想了解 gdb 的詳細(xì)使用請(qǐng)參考 gdb 的指南頁(yè).
表 27.1. 基本 gdb 命令.
命 令 描 述
file 裝入想要調(diào)試的可執(zhí)行文件.
kill 終止正在調(diào)試的程序.
list 列出產(chǎn)生執(zhí)行文件的源代碼的一部分.
next 執(zhí)行一行源代碼但不進(jìn)入函數(shù)內(nèi)部.
step 執(zhí)行一行源代碼而且進(jìn)入函數(shù)內(nèi)部.
run 執(zhí)行當(dāng)前被調(diào)試的程序
quit 終止 gdb
watch 使你能監(jiān)視一個(gè)變量的值而不管它何時(shí)被改變.
break 在代碼里設(shè)置斷點(diǎn), 這將使程序執(zhí)行到這里時(shí)被掛起.
make 使你能不退出 gdb 就可以重新產(chǎn)生可執(zhí)行文件.
shell 使你能不離開(kāi) gdb 就執(zhí)行 UNIX shell 命令.
gdb 支持很多與 UNIX shell 程序一樣的命令編輯特征. 你能象在 bash 或
tcsh里那樣按 Tab 鍵讓 gdb 幫你補(bǔ)齊一個(gè)唯一的命令, 如果不唯一的話 gdb 會(huì)
列出所有匹配的命令. 你也能用光標(biāo)鍵上下翻動(dòng)歷史命令.
gdb 應(yīng)用舉例
本節(jié)用一個(gè)實(shí)例教你一步步的用 gdb 調(diào)試程序. 被調(diào)試的程序相當(dāng)?shù)暮?jiǎn)單,
但它展示了 gdb 的典型應(yīng)用.
下面列出了將被調(diào)試的程序. 這個(gè)程序被稱(chēng)為 greeting , 它顯示一個(gè)簡(jiǎn)單的
問(wèn)候, 再用反序?qū)⑺谐?
#include
main ()
{
char my_string = “hello there”;
my_print (my_string);
my_print2 (my_string);
}
void my_print (char *string)
{
printf (“The string is %s\n”, string);
}
void my_print2 (char *string)
{
char *string2;
int size, i;
size = strlen (string);
string2 = (char *) malloc (size + 1);
for (i = 0; i
2
main ()
{
char my_string = “hello there”;
6
my_print (my_string);
my_print2 (my_string);
}
10
如果按下回車(chē), gdb 將再執(zhí)行一次 list 命令, 給出下列輸出:
my_print (char *string)
{
printf (“The string is %s\n”, string);
}
15
my_print2 (char *string)
{
char *string2;
int size, i;
20 再按一次回車(chē)將列出 greeting 程序的剩余部分:
size = strlen (string);
string2 = (char *) malloc (size + 1);
for (i = 0; i
main ()
{
char my_string = “hello there”;
my_print (my_string);
my_print2 (my_string);
}
my_print (char *string)
{
printf (“The string is %s\n”, string);
}
my_print2 (char *string)
{
char *string2;
int size, size2, i;
size = strlen (string);
size2 = size -1;
string2 = (char *) malloc (size + 1);
for (i = 0; i >>
靜態(tài)函數(shù)象這樣顯示:
total
作為一個(gè)例子, 假設(shè)用 calls 處理下面的程序:
#include
main ()
{
char my_string = “hello there”;
my_print (my_string);
my_print2(my_string);
}
my_print (char *string)
{
printf (“The string is %s\n”, string);
}
my_print2 (char *string)
{
char *string2;
int size, size2, i;
size = strlen (string);
size2 = size -1;
string2 = (char *) malloc (size + 1);
for (i = 0; i
main ()
{
char my_string = “hello there”;
my_print (my_string);
my_print2(my_string);
}
my_print (char *string)
{
printf (“The string is %s\n”, *string);
}
my_print2 (char *string)
{
char *string2;
int size, size2, i;
size = strlen (string);
size2 = size -1;
string2 = (char *) malloc (size + 1);
for (i = 0; i
main () {
char my_string = “hello there”;
my_print (my_string);
my_print2(my_string); }
my_print (char *string)
{
printf (“The string is %s\n”, *string);
}
my_print(char *string) {
char *string2;
int size, size2, i;
size = strlen (string);
size2 = size -1;
string2 = (char *) malloc (size + 1);
for (i = 0; i
main ()
{
char my_string = “hello there”;
my_print (my_string);
my_print2 (my_string);
}
my_print (char *string)
{
printf (“The string is %s\n”, *string);
}
my_print2 (char *string)
{
char *string2;
int size, size2, i;
size = strlen (string);
size2 = size -1;
string2 = (char *) malloc (size + 1);
for (i = 0; i
參數(shù) program_name 是產(chǎn)生 gmon.out 文件的程序的名字.
—
技巧: gprof 產(chǎn)生的剖析數(shù)據(jù)很大, 如果你想檢查這些數(shù)據(jù)的話更好把輸出重定向
到一個(gè)文件里.
—
f2c 和 p2c
f2c 和 p2c 是兩個(gè)源代碼轉(zhuǎn)換程序. f2c 把 FORTRAN 代碼轉(zhuǎn)換為 C 代碼,
p2c 把 Pascal 代碼轉(zhuǎn)換為 C 代碼. 當(dāng)你安裝 GCC 時(shí)這兩個(gè)程序都會(huì)被安裝上去
.
如果你有一些用 FORTRAN 或 Pascal 寫(xiě)的代碼要用 C 重寫(xiě)的話, f2c 和 p2c
對(duì)你非常有用. 這兩個(gè)程序產(chǎn)生的 C 代碼一般不用修改就直接能被 GCC 編譯.
如果要轉(zhuǎn)換的 FORTRAN 或 Pascal 程序比較小的話可以直接使用 f2c 或 p2c
不用加任何選項(xiàng). 如果要轉(zhuǎn)換的程序比較龐大, 包含很多文件的話你可能要用到
一些命令行選項(xiàng).
在一個(gè) FORTRAN 程序上使用 f2c , 輸入下面的命令:
f2c my_fortranprog.f
—
注意: f2c 要求被轉(zhuǎn)換的程序的擴(kuò)展名為 .f 或 a .F .
—
要把一個(gè)Pascal 程序裝換為 C 程序, 輸入下面的命令:
p2c my_pascalprogram.pas
這兩個(gè)程序產(chǎn)生的 C 源代碼的文件名都和原來(lái)的文件名相同, 但擴(kuò)展名由 .f
或 .pas 變?yōu)?.c.
=================================================================
如果你是做工程,還是要懂make,建議你研究一下make
=================================================================
如果你真的對(duì)編譯一無(wú)所知,建議你看一本書(shū)
《編譯原理》 Alfred V.Aho,Ravi Sethi,Jeffrey D.Ullman
另外呢,《現(xiàn)代操作系統(tǒng)》,基礎(chǔ)的東西要學(xué)好!
另外的另外呢,看一下gcc的官方文檔!講解很詳細(xì)!既然要學(xué)電腦,學(xué)編程,不會(huì)英文是不行的!
起碼凳頌要會(huì)看!
===================
另外的另外的另外:makefile….編程棗敗鄭一定要知道m(xù)akefile。具體搜一下:跟我一起寫(xiě)makefile
我可以給你稍微講一下:
gcc是一個(gè)編譯器,作用是將語(yǔ)言代碼編譯為二進(jìn)制文件。它支持各種語(yǔ)言,幾乎全能!編譯C,需要C庫(kù)的支持,編譯java,需要jdk的支持!C++,就需要C++庫(kù)的支持。簡(jiǎn)單說(shuō),作用就是翻譯!
語(yǔ)言就像是現(xiàn)實(shí)世界的語(yǔ)言一樣!語(yǔ)言用來(lái)表達(dá)意思,gcc所編譯的語(yǔ)言也是用來(lái)表達(dá)意思,只不過(guò)是機(jī)器的意思!我想你應(yīng)該知道匯編!匯編直接表達(dá)硬件,有他特殊的地位,C語(yǔ)言可以表達(dá)更枯早高層次的意思!
還有啊,別拿分?jǐn)?shù)來(lái)勾搭人了!百度的分?jǐn)?shù)沒(méi)什么用處?。?!
gcc -S *.c 預(yù)處理+反匯編
linux c程序編譯原理的介紹就聊到這里吧,感謝你花時(shí)間閱讀本站內(nèi)容,更多關(guān)于linux c程序編譯原理,深入了解:linux下c程序編譯的原理和流程,Linux中,運(yùn)行一個(gè)C語(yǔ)言程序如何運(yùn)行,請(qǐng)問(wèn)linux下,gcc編譯程序的過(guò)程(從讀取源文件到制作可執(zhí)行程序中間所有過(guò)程,越詳細(xì)越好)的信息別忘了在本站進(jìn)行查找喔。
成都網(wǎng)站推廣找創(chuàng)新互聯(lián),老牌網(wǎng)站營(yíng)銷(xiāo)公司
成都網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián)(www.cdcxhl.com)專(zhuān)注高端網(wǎng)站建設(shè),網(wǎng)頁(yè)設(shè)計(jì)制作,網(wǎng)站維護(hù),網(wǎng)絡(luò)營(yíng)銷(xiāo),SEO優(yōu)化推廣,快速提升企業(yè)網(wǎng)站排名等一站式服務(wù)。IDC基礎(chǔ)服務(wù):云服務(wù)器、虛擬主機(jī)、網(wǎng)站系統(tǒng)開(kāi)發(fā)經(jīng)驗(yàn)、服務(wù)器租用、服務(wù)器托管提供四川、成都、綿陽(yáng)、雅安、重慶、貴州、昆明、鄭州、湖北十堰機(jī)房互聯(lián)網(wǎng)數(shù)據(jù)中心業(yè)務(wù)。
網(wǎng)頁(yè)標(biāo)題:深入了解:linux下c程序編譯的原理和流程 (linux c程序編譯原理)
瀏覽路徑:http://fisionsoft.com.cn/article/cdpcejo.html


咨詢(xún)
建站咨詢(xún)
