Linux下C 語言編程-3

火星人 @ 2014-03-12 , reply:0


  另外的 C 編程工具

Slackware Linux 的發行版中還包括一些我們尚未提到的 C 開發工具. 本節將介紹這些工具和它們的典型用法.

xxgdb

xxgdb 是 gdb 的一個基於 X Window 系統的圖形界面. xxgdb 包括了命令行版的 gdb 上的所有特性. xxgdb 使你能通過按按鈕來執行常用的命令. 設置了斷點的地方也用圖形來顯示.


你能在一個 Xterm 窗口裡鍵入下面的命令來運行它:

xxgdb

你能用 gdb 里任何有效的命令行選項來初始化 xxgdb . 此外 xxgdb 也有一些特有的命令行選項, 表 27.2 列出了這些選項.


表 27.2. xxgdb 命令行選項.



選 項 描 述

db_name 指定所用調試器的名字, 預設是 gdb.

db_prompt 指定調試器提示符, 預設為 gdb.

gdbinit 指定初始化 gdb 的命令文件的文件名, 預設為 .gdbinit.

nx 告訴 xxgdb 不執行 .gdbinit 文件.

bigicon 使用大圖標.





calls

你可以在 sunsite.unc.edu FTP 站點用下面的路徑:

/pub/Linux/devel/lang/c/calls.tar.Z


來取得 calls , 一些舊版本的 Linux CD-ROM 發行版里也附帶有. 因為它是一個有用的工具, 我們在這裡也介紹一下. 如果你覺得有用的話, 從 BBS, FTP, 或另一張CD-ROM 上弄一個拷貝. calls 調用 GCC 的預處理器來處理給出的源程序文件, 然後輸出這些文件的里的函數調用樹圖.




--------------------------------------------------------------------------------

注意: 在你的系統上安裝 calls , 以超級用戶身份登錄后執行下面的步驟: 1. 解壓和 untar 文件. 2. cd 進入 calls untar 后建立的子目錄. 3. 把名叫 calls 的文件移動到 /usr/bin 目錄. 4. 把名叫 calls.1 的文件移動到目錄 /usr/man/man1 . 5. 刪除 /tmp/calls 目錄. 這些步驟將把 calls 程序和它的指南頁安裝載你的系統上.

--------------------------------------------------------------------------------


當 calls 列印出調用跟蹤結果時, 它在函數後面用中括弧給出了函數所在文件的文件名:

main [test.c]

如果函數並不是向 calls 給出的文件里的, calls 不知道所調用的函數來自哪裡, 則只顯示函數的名字:

printf

calls 不對遞歸和靜態函數輸出. 遞歸函數顯示成下面的樣子:

fact <<< recursive in factorial.c >>>

靜態函數象這樣顯示:

total [static in calculate.c]

作為一個例子, 假設用 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 < size; i++)


string2[size2 - i] = string[i];


string2[size] = "\0";


printf ("The string printed backward is %s\n", string2);


}

將產生如下的輸出:

1 main [test.c]


2 my_print [test.c]


3 printf


4 my_print2 [test.c]


5 strlen


6 malloc


7 printf

calls 有很多命令行選項來設置不同的輸出格式, 有關這些選項的更多信息請參考 calls 的指南頁. 方法是在命令行上鍵入 calls -h .



cproto

cproto 讀入 C 源程序文件並自動為每個函數產生原型申明. 用 cproto 可以在寫程序時為你節省大量用來定義函數原型的時間.

如果你讓 cproto 處理下面的代碼:

#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 < size; i++)


string2[size2 - i] = string[i];


string2[size] = "\0";


printf ("The string printed backward is %s\n", string2);


}

你將得到下面的輸出:

/* test.c */


int main(void);


int my_print(char *string);


int my_print2(char *string);

這個輸出可以重定向到一個定義函數原型的包含文件里.

indent

indent 實用程序是 Linux 里包含的另一個編程實用工具. 這個工具簡單的說就為你的代碼產生美觀的縮進的格式. indent 也有很多選項來指定如何格式化你的源代碼.這些選項的更多信息請看indent 的指南頁, 在命令行上鍵入 indent -h .


下面的例子是 indent 的預設輸出:


運行 indent 以前的 C 代碼:


#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 < size; i++)


string2[size2 - i] = string[i];


string2[size] = "\0";



printf ("The string printed backward is %s\n", string2);


}

運行 indent 后的 C 代碼:

#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 < size; i++)


string2[size2 - i] = string[i];


string2[size] = "\0";


printf ("The string printed backward is %s\n", string2);


}

indent 並不改變代碼的實質內容, 而只是改變代碼的外觀. 使它變得更可讀, 這永遠是一件好事.

gprof

gprof 是安裝在你的 Linux 系統的 /usr/bin 目錄下的一個程序. 它使你能剖析你的程序從而知道程序的哪一個部分在執行時最費時間.

gprof 將告訴你程序里每個函數被調用的次數和每個函數執行時所佔時間的百分比. 你如果想提高你的程序性能的話這些信息非常有用.


為了在你的程序上使用 gprof, 你必須在編譯程序時加上 -pg 選項. 這將使程序在每次執行時產生一個叫 gmon.out 的文件. gprof 用這個文件產生剖析信息.


在你運行了你的程序併產生了 gmon.out 文件后你能用下面的命令獲得剖析信息:


gprof

參數 program_name 是產生 gmon.out 文件的程序的名字.


--------------------------------------------------------------------------------

技巧: gprof 產生的剖析數據很大, 如果你想檢查這些數據的話最好把輸出重定向到一個文件里.

--------------------------------------------------------------------------------


f2c 和 p2c

f2c 和 p2c 是兩個源代碼轉換程序. f2c 把 FORTRAN 代碼轉換為 C 代碼, p2c 把 Pascal 代碼轉換為 C 代碼. 當你安裝 GCC 時這兩個程序都會被安裝上去.

如果你有一些用 FORTRAN 或 Pascal 寫的代碼要用 C 重寫的話, f2c 和 p2c 對你非常有用. 這兩個程序產生的 C 代碼一般不用修改就直接能被 GCC 編譯.


如果要轉換的 FORTRAN 或 Pascal 程序比較小的話可以直接使用 f2c 或 p2c 不用加任何選項. 如果要轉換的程序比較龐大, 包含很多文件的話你可能要用到一些命令行選項.


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


f2c my_fortranprog.f


--------------------------------------------------------------------------------

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

--------------------------------------------------------------------------------


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

p2c my_pascalprogram.pas

這兩個程序產生的 C 源代碼的文件名都和原來的文件名相同, 但擴展名由 .f 或 .pas 變為 .c.




[火星人 via ] Linux下C 語言編程-3已經有331次圍觀

http://www.coctec.com/docs/program/show-post-72478.html