Programming 版 (精华区)

发信人: worldguy (蓝色天际), 信区: Programming
标  题: [转]如何阅读源代码(4)--总结
发信站: 哈工大紫丁香 (2004年04月16日20:53:23 星期五), 站内信件


最后,对于在这篇文章中提到的分析源代码程序的一些方法做一下小结,以作为本文的
结束。

分析一个源代码,一个有效的方法是:

1、阅读源代码的说明文档,比如本例中的README, 作者写的非常的详细,仔细读过之后
,在阅读程序的时候往往能够从README文件中找到相应的说明,从而简化了源程序的阅读
工作。

2、如果源代码有文档目录,一般为doc或者docs, 最好也在阅读源程序之前仔细阅读,
因为这些文档同样起了很好的说明注释作用。

3、从makefile文件入手,分析源代码的层次结构,找出哪个是主程序,哪些是函数包。
这对于快速把握程序结构有很大帮助。

4、从main函数入手,一步一步往下阅读,遇到可以猜测出意思来的简单的函数,可以跳
过。但是一定要注意程序中使用的全局变量(如果是C程序),可以把关键的数据结构说明
拷贝到一个文本编辑器中以便随时查找。

5、分析函数包(针对C程序),要注意哪些是全局函数,哪些是内部使用的函数,注意e
xtern关键字。对于变量,也需要同样注意。先分析清楚内部函数,再来分析外部函数,
因为内部函数肯定是在外部函数中被调用的。

6、需要说明的是数据结构的重要性:对于一个C程序来说,所有的函数都是在操作同一
些数据,而由于没有较好的封装性,这些数据可能出现在程序的任何地方,被任何函数修
改,所以一定要注意这些数据的定义和意义,也要注意是哪些函数在对它们进行操作,做
了哪些改变。

7、在阅读程序的同时,最好能够把程序存入到cvs之类的版本控制器中去,在需要的时
候可以对源代码做一些修改试验,因为动手修改是比仅仅是阅读要好得多的读程序的方法

在你修改运行程序的时候,可以从cvs中把原来的代码调出来与你改动的部分进行比较(d
iff命令), 可以看出一些源代码的优缺点并且能够实际的练习自己的编程技术。

8、阅读程序的同时,要注意一些小工具的使用,能够提高速度,比如vi中的查找功能,
模式匹配查找,做标记,还有grep,find这两个最强大最常用的文本搜索工具的使用。


对于一个Unix/Linux下面以命令行方式运行的程序,有这么一些套路,大家可以在阅读
程序的时候作为参考。

1、在程序开头,往往都是分析命令行,根据命令行参数对一些变量或者数组,或者结构
赋值,后面的程序就是根据这些变量来进行不同的操作。
2、分析命令行之后,进行数据准备,往往是计数器清空,结构清零等等。
3、在程序中间有一些预编译选项,可以在makefile中找到相应部分。
4、注意程序中对于日志的处理,和调试选项打开的时候做的动作,这些对于调试程序有
很大的帮助。
5、注意多线程对数据的操作。(这在本例中没有涉及)


结束语:
当然,在这篇文章中,并没有阐述所有的阅读源代码的方法和技巧,也没有涉及任何辅
助工具(除了简单的文本编辑器),也没有涉及面向对象程序的阅读方法。我想把这些留
到以后再做讨论。也请大家可以就这些话题展开讨论。

(※ 来源:·北极星BBS站 bjsing.net·[FROM: 南大小百合BBS])

--
No more you blind me heaven,
no more you bury me hell,
be powderize indifferent gods,
be lighted all the hears.

※ 来源:·哈工大紫丁香 bbs.hit.edu.cn·[FROM: 202.118.239.18]
[百宝箱] [返回首页] [上级目录] [根目录] [返回顶部] [刷新] [返回]
Powered by KBS BBS 2.0 (http://dev.kcn.cn)
页面执行时间:3.299毫秒