日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
深入了解:linux下c程序編譯的原理和流程 (linux c程序編譯原理)

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

在Linux環(huán)境下,C程序是一種較為常見的程序語言,因此了解其編譯的原理和流程對于Linux技術(shù)人員來說非常重要。本文將介紹 Linux下C程序編譯的原理和流程的相關(guān)知識點。

一、編譯器

編譯器是將我們編寫的源程序轉(zhuǎn)換為可執(zhí)行文件的工具。在Linux中,常見的編譯器有g(shù)cc和clang。gcc是GNU C Compiler的縮寫,它是在Linux系統(tǒng)中最常用的編譯器,而clang則是一個可以替代gcc的編譯器,它具有更好的編譯速度和優(yōu)化效果。

二、編譯的過程

編譯的過程分為四個階段:預(yù)處理、編譯、匯編和鏈接。

預(yù)處理階段:該階段主要用來處理源文件中的預(yù)處理指令,如#include和#define等。預(yù)處理器將源代碼中出現(xiàn)的特定字符序列進行處理,生成新的C源代碼文件,并將其名稱以.i作為擴展名。

編譯階段:該階段將預(yù)處理后的C源代碼分割成多個小模塊,每個小模塊包含一個函數(shù),一個類或一段代碼段。編譯器將這些小模塊翻譯成匯編語言,然后生成匯編語言文件并以.s為擴展名保存。

匯編階段:該階段是將匯編語言文件轉(zhuǎn)換為機器語言文件。匯編器將匯編語言文件翻譯為二進制目標文件,并以.o為擴展名保存。

鏈接階段:該階段主要是將預(yù)編譯、編譯、匯編階段的多個目標文件鏈接成一個可執(zhí)行文件。鏈接器將這些目標文件中的全局變量、函數(shù)等符號進行統(tǒng)一,然后生成可執(zhí)行文件。

三、Makefile

在Linux下,我們將源程序轉(zhuǎn)換為可執(zhí)行文件時需要經(jīng)過多個工具的處理,這些工具的操作指令相較于我們手動敲入,略顯繁瑣。因此,使用Makefile可以幫助我們將多個指令整合并運行,提升了編譯的效率和精度。Makefile是一個特殊的文件,它提供了一種簡單的方法來自動化源代碼和可執(zhí)行文件之間的轉(zhuǎn)換過程。

在Makefile中,我們可以定義源程序、編譯器、鏈接器等信息,然后使用make工具自動化執(zhí)行這個文件的內(nèi)容,從而實現(xiàn)源程序轉(zhuǎn)換為可執(zhí)行文件的過程。Makefile在C程序的編譯過程中扮演了非常重要的角色,形成了一個自動化的編譯過程。

四、

Linux下C程序編譯的整個過程分為預(yù)處理、編譯、匯編和鏈接四個階段。在實際編譯過程中,我們可以使用gcc等編譯器和Makefile來簡化編譯過程,提升編譯效率和精度。了解Linux下C程序編譯的原理和流程對于Linux技術(shù)人員掌握C程序是非常有幫助的。

相關(guān)問題拓展閱讀:

  • Linux中,運行一個C語言程序如何運行
  • 請問linux下,gcc編譯程序的過程(從讀取源文件到制作可執(zhí)行程序中間所有過程,越詳細越好)

Linux中,運行一個C語言程序如何運行

這個:

網(wǎng)返遲桐旦滑頁鏈接漏坦

1、打開kali linux的終端。創(chuàng)建一個文件并命名為test.c。在終端輸入:touch test.c。

2、可以看到已經(jīng)生成了一個后綴為test.c的源文件。然后用vim工具打開這個文件并編寫代碼。在終端中輸入:vim test.c或者gvim test.c打開這個文件并編寫代碼。

3、編寫完了這個代碼?,F(xiàn)在開始編譯源文件。在終端中輸入:gcc test.cgcc是linux自帶的c語言編譯器。如果是windows則要用ide工具來編譯。linux系統(tǒng)一般寫C語言用gcc +vim+gdb三個自帶畝李的工具就可以了。

4、打完gcc test.c編譯完C源文件。然后就可以看見a.out的文件。一般linux系統(tǒng)就默認為a.out為編譯完的文件?,F(xiàn)在運行a.out文件。在a.out文件的目錄下打開終端并迅鍵遲輸入./a.out就是運行文件了。

5、如果想要編譯完的文件名不要用a.out文件。就可以在編譯時打入.gcc test.c -o test.out然后就可以看見有一個test.out.文件 了。-o后面跟著的編譯生成的文件名。

6、再運行test.out在終端亮清中輸入./test.out結(jié)果如圖。這樣在linux系統(tǒng)下編譯并運行C語言就完成了。

在Linux中,可以使用gcc編譯器編譯氏槐春C語言程序,生成可執(zhí)行文件,并最終執(zhí)行。

具體步驟如下:

1、編譯。

由.c文件生成.o文件,寫作:

gcc a.c -o a.o -c

這個命令可以將a.c編譯成a.o。

如果存在多個文件,可殲?zāi)鸵灾饌€編譯,即a.c b.c… 生成a.o b.o…等。

2、鏈接。

由.o文件生成可執(zhí)行文件,寫作:

gcc a.o b.o c.o -o a.out

這個命令將a.o b.o c.o三個目標文件明缺,生成可執(zhí)行文件a.out。

3、執(zhí)行。

調(diào)用命令:

./a.out

即可執(zhí)行生成的可執(zhí)行文件a.out。

4、注意事項:

(1) 當文件較少時,可以省略目標文件步驟,編譯鏈接一步執(zhí)行,如:

gcc a.c b.c c.c -o a.out

(2) 提供的示例為最基礎(chǔ)的編譯功能,在實際應(yīng)用中g(shù)cc有很豐富的編譯選項,根據(jù)需求進行添加。

(3) 當項目包含文件較多時,可以使用makefile進行管理。

如果已經(jīng)寫好了源文件,那么cd 進所在的目錄gcc filename.c -o filename;./filename;找到一個學(xué)習(xí)linux的好方法簡頃旦,另外你是感興趣的話可以看下劉遄老師寫的《Linux就該這么學(xué)》作為入門的書籍,覺乎侍得不錯攔擾的話采納下哦~

編譯生成可執(zhí)行文件,然后運行即可,沒什么特殊的呀

請問linux下,gcc編譯程序的過程(從讀取源文件到制作可執(zhí)行程序中間所有過程,越詳細越好)

1.gcc -E *.c 預(yù)處理,把宏,頭文件展開缺念

2.gcc -S *.c 預(yù)處理+反匯編

3.gcc -c *.c 預(yù)稿坦處理+反匯編+obj文伏敬困件

4.gcc -o *.o 預(yù)處理+反匯編+obj文件+鏈接,生成可執(zhí)行文件

大概就這樣吧,記不住了都

Linux的發(fā)行版中包含了很多軟件開發(fā)工具. 它們中的很多是用于 C 和 C++應(yīng)用程

序開發(fā)的.

GNU C 編譯器

用 gdb 來調(diào)試GCC應(yīng)用程序

你也能看到隨 Linux 發(fā)行的其他有用的 C 編程工具. 這些工具包括源程序美

化程序(pretty print programs), 附加的調(diào)試工具, 函數(shù)原型自動生成工具

(automatic function prototypers).

GNU C 編譯器

隨 Slackware Linux 發(fā)行的 GNU C 編譯器(GCC)是一個全功能的 ANSI C 兼

容編譯器. 如果你熟悉其他操作系統(tǒng)或硬件平臺上的一種 C 編譯器, 你將能很快

地掌握 GCC.

使用 GCC

通常后跟一些選項和文件名來使用 GCC 編譯器. gcc 命令的基本用法如下:

gcc

命令行選項指定的操作將在命令行上每個給出的文件上執(zhí)行. 下一小節(jié)將敘述

一些你會最常用到的選項.

GCC 選項

GCC 有超過100個的編譯選項可用. 這些選項中的許多你可能永遠都不會用到,

但一些主要的選項將會頻繁用到. 很多的 GCC 選項包括一個以上的字符. 因此你

必須為每個選項指定各自的連字符, 并且就象大多數(shù) Linux 命令一樣你不能在一

個單獨的連字符后跟一組選項. 例如, 下面的兩個命令是不同的:

gcc -p -g test.c

gcc -pg test.c

之一條命令告訴 GCC 編譯 test.c 時為 prof 命令建立剖析(profile)信息并

且把調(diào)試信息加入到可執(zhí)行的文件里. 第二條命令只告訴 GCC 為 gprof 命令建立

剖析信息.

當你不用任何選項編譯一個程序時, GCC 將會建立(假定編譯成功)一個名為

a.out 的可執(zhí)行文件. 例如, 下面的命令將在當前目錄下產(chǎn)生一個叫 a.out 的文

件:

gcc test.c

你能用 -o 編譯選項來為將產(chǎn)生的可執(zhí)行文件指定一個文件名來代替 a.out.

例如, 將一個叫 count.c 的 C 程序編譯為名叫 count 的可執(zhí)行文件, 你將輸入

下面的命令:

gcc -o count count.c

注意: 當你使用 -o 選項時, -o 后面必須跟一個文件名.

GCC 同樣有指定編譯器處理多少的編譯選項. -c 選項告訴 GCC 僅把源代碼編

譯為目標代碼而跳過匯編和連接的步驟. 這個閉掘選項使用的非常頻繁因為它使得編譯

多個 C 程序時速度更快并且更謹氏易于管理. 缺省時 GCC 建立的目標代碼文件有一個

.o 的擴展名.

-S 編譯選項告訴 GCC 在為 C 代碼產(chǎn)生了匯編語言文件后停止編譯. GCC 產(chǎn)

生的匯編語言文件的缺省擴展名是 .s . -E 選項指示編譯器僅對輸入文件進行預(yù)

處理. 當這個選項被使用時, 預(yù)處理器的輸出被送到標準輸出而不是儲存在文件里。

優(yōu) 化 選 項

當你用 GCC 編譯 C 代碼時, 它會試著用最少的時間完成編譯并且使編譯后的

代碼易于調(diào)試. 易于調(diào)試意味著編譯后的代碼與源代碼有同樣的執(zhí)行次序, 編譯后

的代碼沒有經(jīng)過優(yōu)化. 有很多選項可用于告訴 GCC 在耗費更多編譯時間和犧牲易

調(diào)試性的基礎(chǔ)上產(chǎn)生更小更快的可執(zhí)行文件. 這些選項中最典型的是-O 和 -O2 選

項.

-O 選項告訴 GCC 對源代碼進行基本優(yōu)化. 這些優(yōu)化在大多數(shù)情況下都會使程

序執(zhí)行的更快. -O2 選項告訴 GCC 產(chǎn)生盡可能小和盡可能快的代碼. -O2 選項將

使編譯的速度比使用 -O 時慢. 但通常產(chǎn)生的祥態(tài)散代碼執(zhí)行速度會更快.

除了 -O 和 -O2 優(yōu)化選項外, 還有一些低級選項用于產(chǎn)生更快的代碼. 這些

選項非常的特殊, 而且更好只有當你完全理解這些選項將會對編譯后的代碼產(chǎn)生什

么樣的效果時再去使用. 這些選項的詳細描述, 請參考 GCC 的指南頁, 在命令行

上鍵入 man gcc .

調(diào)試和剖析選項

GCC 支持數(shù)種調(diào)試和剖析選項. 在這些選項里你會最常用到的是 -g 和 -pg

選項.

-g 選項告訴 GCC 產(chǎn)生能被 GNU 調(diào)試器使用的調(diào)試信息以便調(diào)試你的程序.

GCC 提供了一個很多其他 C 編譯器里沒有的特性, 在 GCC 里你能使 -g 和 -O (

產(chǎn)生優(yōu)化代碼)聯(lián)用. 這一點非常有用因為你能在與最終產(chǎn)品盡可能相近的情況下

調(diào)試你的代碼. 在你同時使用這兩個選項時你必須清楚你所寫的某些代碼已經(jīng)在優(yōu)

化時被 GCC 作了改動. 關(guān)于調(diào)試 C 程序的更多信息請看下一節(jié)”用 gdb 調(diào)試 C

程序” .

-pg 選項告訴 GCC 在你的程序里加入額外的代碼, 執(zhí)行時, 產(chǎn)生 gprof 用的

剖析信息以顯示你的程序的耗時情況. 關(guān)于 gprof 的更多信息請參考 “gprof” 一

節(jié).

用 gdb 調(diào)試 GCC 程序

Linux 包含了一個叫 gdb 的 GNU 調(diào)試程序. gdb 是一個用來調(diào)試 C 和

C++ 程序的強力調(diào)試器. 它使你能在程序運行時觀察程序的內(nèi)部結(jié)構(gòu)和內(nèi)存的使用

情況. 以下是 gdb 所提供的一些功能:

它使你能監(jiān)視你程序中變量的值.

它使你能設(shè)置斷點以使程序在指定的代碼行上停止執(zhí)行.

它使你能一行行的執(zhí)行你的代碼.

在命令行上鍵入 gdb 并按回車鍵就可以運行 gdb 了, 如果一切正常的話,

gdb 將被啟動并且你將在屏幕上看到類似的內(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)

當你啟動 gdb 后, 你能在命令行上指定很多的選項. 你也可以以下面的方式

來運行 gdb :

gdb

當你用這種方式運行 gdb , 你能直接指定想要調(diào)試的程序. 這將告訴gdb 裝

入名為 fname 的可執(zhí)行文件. 你也可以用 gdb 去檢查一個因程序異常終止而產(chǎn)生

的 core 文件, 或者與一個正在運行的程序相連. 你可以參考 gdb 指南頁或在命

令行上鍵入 gdb -h 得到一個有關(guān)這些選項的說明的簡單列表.

為調(diào)試編譯代碼(Compiling Code for Debugging)

為了使 gdb 正常工作, 你必須使你的程序在編譯時包含調(diào)試信息. 調(diào)試信息

包含你程序里的每個變量的類型和在可執(zhí)行文件里的地址映射以及源代碼的行號.

gdb 利用這些信息使源代碼和機器碼相關(guān)聯(lián).

在編譯時用 -g 選項打開調(diào)試選項.

gdb 基本命令

gdb 支持很多的命令使你能實現(xiàn)不同的功能. 這些命令從簡單的文件裝入到

允許你檢查所調(diào)用的堆棧內(nèi)容的復(fù)雜命令, 表27.1列出了你在用 gdb 調(diào)試時會用

到的一些命令. 想了解 gdb 的詳細使用請參考 gdb 的指南頁.

表 27.1. 基本 gdb 命令.

命 令 描 述

file 裝入想要調(diào)試的可執(zhí)行文件.

kill 終止正在調(diào)試的程序.

list 列出產(chǎn)生執(zhí)行文件的源代碼的一部分.

next 執(zhí)行一行源代碼但不進入函數(shù)內(nèi)部.

step 執(zhí)行一行源代碼而且進入函數(shù)內(nèi)部.

run 執(zhí)行當前被調(diào)試的程序

quit 終止 gdb

watch 使你能監(jiān)視一個變量的值而不管它何時被改變.

break 在代碼里設(shè)置斷點, 這將使程序執(zhí)行到這里時被掛起.

make 使你能不退出 gdb 就可以重新產(chǎn)生可執(zhí)行文件.

shell 使你能不離開 gdb 就執(zhí)行 UNIX shell 命令.

gdb 支持很多與 UNIX shell 程序一樣的命令編輯特征. 你能象在 bash 或

tcsh里那樣按 Tab 鍵讓 gdb 幫你補齊一個唯一的命令, 如果不唯一的話 gdb 會

列出所有匹配的命令. 你也能用光標鍵上下翻動歷史命令.

gdb 應(yīng)用舉例

本節(jié)用一個實例教你一步步的用 gdb 調(diào)試程序. 被調(diào)試的程序相當?shù)暮唵?

但它展示了 gdb 的典型應(yīng)用.

下面列出了將被調(diào)試的程序. 這個程序被稱為 greeting , 它顯示一個簡單的

問候, 再用反序?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

如果按下回車, 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 再按一次回車將列出 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

作為一個例子, 假設(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ù)的話更好把輸出重定向

到一個文件里.

f2c 和 p2c

f2c 和 p2c 是兩個源代碼轉(zhuǎn)換程序. f2c 把 FORTRAN 代碼轉(zhuǎn)換為 C 代碼,

p2c 把 Pascal 代碼轉(zhuǎn)換為 C 代碼. 當你安裝 GCC 時這兩個程序都會被安裝上去

.

如果你有一些用 FORTRAN 或 Pascal 寫的代碼要用 C 重寫的話, f2c 和 p2c

對你非常有用. 這兩個程序產(chǎn)生的 C 代碼一般不用修改就直接能被 GCC 編譯.

如果要轉(zhuǎn)換的 FORTRAN 或 Pascal 程序比較小的話可以直接使用 f2c 或 p2c

不用加任何選項. 如果要轉(zhuǎn)換的程序比較龐大, 包含很多文件的話你可能要用到

一些命令行選項.

在一個 FORTRAN 程序上使用 f2c , 輸入下面的命令:

f2c my_fortranprog.f

注意: f2c 要求被轉(zhuǎn)換的程序的擴展名為 .f 或 a .F .

要把一個Pascal 程序裝換為 C 程序, 輸入下面的命令:

p2c my_pascalprogram.pas

這兩個程序產(chǎn)生的 C 源代碼的文件名都和原來的文件名相同, 但擴展名由 .f

或 .pas 變?yōu)?.c.

=================================================================

如果你是做工程,還是要懂make,建議你研究一下make

=================================================================

如果你真的對編譯一無所知,建議你看一本書

《編譯原理》 Alfred V.Aho,Ravi Sethi,Jeffrey D.Ullman

另外呢,《現(xiàn)代操作系統(tǒng)》,基礎(chǔ)的東西要學(xué)好!

另外的另外呢,看一下gcc的官方文檔!講解很詳細!既然要學(xué)電腦,學(xué)編程,不會英文是不行的!

起碼凳頌要會看!

===================

另外的另外的另外:makefile….編程棗敗鄭一定要知道m(xù)akefile。具體搜一下:跟我一起寫makefile

我可以給你稍微講一下:

gcc是一個編譯器,作用是將語言代碼編譯為二進制文件。它支持各種語言,幾乎全能!編譯C,需要C庫的支持,編譯java,需要jdk的支持!C++,就需要C++庫的支持。簡單說,作用就是翻譯!

語言就像是現(xiàn)實世界的語言一樣!語言用來表達意思,gcc所編譯的語言也是用來表達意思,只不過是機器的意思!我想你應(yīng)該知道匯編!匯編直接表達硬件,有他特殊的地位,C語言可以表達更枯早高層次的意思!

還有啊,別拿分數(shù)來勾搭人了!百度的分數(shù)沒什么用處啊??!

gcc -S *.c 預(yù)處理+反匯編

linux c程序編譯原理的介紹就聊到這里吧,感謝你花時間閱讀本站內(nèi)容,更多關(guān)于linux c程序編譯原理,深入了解:linux下c程序編譯的原理和流程,Linux中,運行一個C語言程序如何運行,請問linux下,gcc編譯程序的過程(從讀取源文件到制作可執(zhí)行程序中間所有過程,越詳細越好)的信息別忘了在本站進行查找喔。

成都網(wǎng)站推廣找創(chuàng)新互聯(lián),老牌網(wǎng)站營銷公司
成都網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián)(www.cdcxhl.com)專注高端網(wǎng)站建設(shè),網(wǎng)頁設(shè)計制作,網(wǎng)站維護,網(wǎng)絡(luò)營銷,SEO優(yōu)化推廣,快速提升企業(yè)網(wǎng)站排名等一站式服務(wù)。IDC基礎(chǔ)服務(wù):云服務(wù)器、虛擬主機、網(wǎng)站系統(tǒng)開發(fā)經(jīng)驗、服務(wù)器租用、服務(wù)器托管提供四川、成都、綿陽、雅安、重慶、貴州、昆明、鄭州、湖北十堰機房互聯(lián)網(wǎng)數(shù)據(jù)中心業(yè)務(wù)。


分享文章:深入了解:linux下c程序編譯的原理和流程 (linux c程序編譯原理)
標題路徑:http://www.5511xx.com/article/cdpcejo.html