庞大资源库的计算机教程网站!
设为首页
加入收藏
总编信箱
投稿或申请专栏请先 [登 陆]
首页 操作系统 程序设计 图形图像 媒体动画 机械电子 WEB开发 数 据 库 办公系列 路由技术 网络原理 网络应用
认证考试 安全技术
首页>操作系统>Linux>编程开发>正文
资料搜索
Google搜索
Google
返回上级列表

推荐文章

快速保存网页中所有图片的方法
Windows中让光驱巧妙“隐身”技
防范非法用户入侵Win 2000/XP系
两款比较典型的ASP木马防范方法
有关表格边框的css语法整理
Windows XP中可以被禁用的服务
SQL Server导出导入数据方法
Javascript所有对象的属性的获
网页(HTML)中的特殊字符
与篮球共舞,尽显模式本色
QQ病毒的手工清除方法
Photoshop为极品美女打造性感睫
天衣无缝:IIS与PHP水火也相容
SQL Server存储过程编写和优化

Linux下C 语言编程-3

 作者:本站收集   日期:2005-4-13
字号选择〖 〗/ 双击滚屏 单击停止   
另外的 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.
上一篇:GNU中的Makefile    下一篇:Linux下C 语言编程-2  
[发送给好友]  [关闭窗口]  [返回顶部]   转载请注明来源:www.it00.com   
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
责任编辑: 原点 投稿作者: 本站收集
信息来源: 网络 录入时间: 2005-4-13
关于我们 - 广告服务 - 版权申明 - 网站地图 - 联系方式 - 总编信箱 - 会员投稿