`
Mybeautiful
  • 浏览: 297060 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

如何阅读源代码

阅读更多

     众所周知,要想写出好的程序,除了要经常写之外,还有看看别人是怎么写的,所以读别人的程序是非常重要的;如今是个信息交换十分发达的时代,你可以轻易的就看到顶尖级选手的代码;开源事业蒸蒸日上,确实是所有程序员的福音。但如何阅读别人的代码呢?尤其对于初学者而言,确实是个难题,就像碰到一漂亮的刺猬,实在不知道如何下嘴。

 

     规则一,你读的越多,你就越容易读懂,因为高手写程序的思维都是趋同的,正所谓万剑归宗;当然你要找到这个“同”,是需要功力的。设计模式是“同”之一,一般碰到同类型问题,大家都倾向于用同样的“模式”处理,所以你了解了这种模式,下次你看某个源程序时,其中有类似问题,你肯定就会想到作者很可能是用这种模式处理的。这样你就会更容易看清作者的思路,理清程序的脉络。

 

    规则二,由上之下,逐步求精。不要一开始就想把所有的细节搞清楚,否则你就会陷入“只见树木,不见森林”的困境。先要理清程序的脉络,知道那个包是干什么的,那个类是干什么的,他们之间有什么样的联系。然后在一个一个问题深究。其思想就是,大而化下,再大而化小...你要细到什么程度,取决于你的要求及期望。一般我看到包,类一层就不会看了,除非我对某个算法感兴趣,我也会仔细在研究之。其实这也是面向对象的设计思想,由上至下,而不是由下至上。无论你看到哪一层,你都可以说“我了解这个框架的实现”,只是看到的粒度不同而已。

 

    规则三,调试。我认为调试程序员最重要的功底,而不是最重要的之一。断点下在哪里最有可能定位问题所在,但又不浪费时间,记住断点并不是越多越好。什么时候应该用条件断点。碰到一个新的程序,你肯定要在入口Main里面下个断点,这个Main就会分几个枝出来,然后对你感兴趣的枝再设断点(Main中也许就不需要设了),依次类推。当然,如何用更好的方法调试某个程序,是需要具体问题具体分析的。这需要经验的积累。曾经有2两个3年经验的兄弟问我同一个问题"这个IF为什么不进去?", 我说只有一种可能就是“IF的条件不满足。”,在IF那设个断点,一个一个条件看。

 

     我也曾阅读过一些源码,如Cindy(一个跟Mina差不多的NIO框架,国人写的),2007年我花了大概一周的晚上,搞清楚了所有细节,然后abbot,一个Java写的自动化测试工具,我研究了一个月,最终肢解并扩展用在我的项目中,还有Mina实现的Ftp,差不多两天就弄清楚了。最近扩展了csvddbc, 增加了cache功能,实现了类似mysql的LIMIT语法。每读一个程序,我都会有收获,"原来这个问题可以这样处理,或是这样处理更好,效率更高"。把别人好的思想装到自己的脑袋了,按老俞的说法,就是"让自己更有价值。"

 

     与其天天记Struct,Spring的配置,还不如了解其思想,当你拥有了足够多的思想时,学习新的框架就会更简单,因为你会觉得"要是是我,我一定会这样处理",结果作者果然就是如你所然,这其实就是规则一。

 

     对刚进公司的新人也是一样,组长给你一个项目代码,让你自己看,也许有些过时的文档;你会非常头大,组长说"你有问题来问我。"经验告诉我,你其实有问题但是都不知道该怎么问。所以你可以依据以上规则,静下心来,耐心的调试,分析,总结,记得要记笔记。不断的假设、猜想,然后证实、证伪。终于你发现,原来是这样,也没想的那么难。

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

张瑜,Mybeautiful, zhangyu0182@sina.com.

 

12
2
分享到:
评论
5 楼 月光照着我 2015-07-19  
谢谢~~~
4 楼 xingkonghuachen 2014-03-19  
感觉说得很好,努力中[size=x-small][/size]
3 楼 lwkjob 2013-05-20  
似懂非懂中。。。。谢谢
2 楼 ljl.java 2012-02-03  
1 楼 白云飞 2011-08-24  
good job!

相关推荐

    清除c/c++代码中条件编译部分的程序,帮助阅读源代码,生成好的tags

    网上众多的开源C/C++代码,因为跨平台的需要,参杂了许多的条件编译语句,对阅读源代码造成了不方便,而且用ctags等工具生成源代码的tags文件时会有些妨碍,本工具就是用来预处理这些条件编译的,将未定义的区域自动...

    学会阅读源代码

    在计算通信领域,写几段使人类同胞能够理解的文字,实在比敲几行不会使编译器或者解释器呕吐的软件代码要困难得多。 这就是为什么每当涉及到代码,几乎所有文档都弱爆了。因为写东西给人看,比写给机器看难得多,在...

    关于那些阅读源代码技巧

    阅读源代码是软件开发中的重要技能,它可以帮助开发者理解软件的工作原理,学习优秀的设计模式,同时在解决问题时提供思路。文章提供了关于阅读源代码的技巧和方法,其中涉及多个方面,包括目的、工具、知识准备、...

    swift-Sources一个简化的github客户端很容易且舒适地阅读源代码

    标题中的“swift-Sources”指的是一个基于Swift编程语言开发的项目,它的主要目的是提供一个简洁、易用的GitHub客户端,方便用户浏览和阅读源代码。这个客户端被称为“Sources”,其设计初衷是为开发者提供一个舒适...

    用Source Insight打开linux内核源代码

    4. Source Insight 工具的使用:Source Insight 是一个支持多种开发语言的编辑器,可以用来阅读源代码。其功能包括查找、定位、彩色显示等。可以用 Source Insight 打开 Linux 内核源代码,了解代码的结构和内容。 ...

    javascript源代码下载

    通过阅读源代码,开发者可以深入理解JavaScript的工作原理、设计模式以及最佳实践。 2. **代码调试与优化**:掌握源代码可以帮助开发者更好地调试和优化自己的JavaScript程序。 3. **二次开发**:许多开源项目提供了...

    linux 经典源代码

    通过阅读源代码,我们可以理解如何实现这些功能,例如多任务调度(如CFS调度器)和内存分配策略(如伙伴系统)。 2. **设备驱动**:Linux支持各种硬件设备,其源代码包含了大量设备驱动程序。这些驱动程序允许内核...

    嵌入式源代码source

    嵌入式源代码是开发嵌入式系统时不可或缺的一部分,它是实现特定功能、运行在微控制器或微处理器上的软件程序。对于初学者来说,理解并分析这些源代码...记得在阅读源代码时,结合相关文档和教程,以加深理解和应用。

    Linux内核源代码的阅读及相关工具介绍

    阅读源代码通常采用纵向和横向相结合的方式。纵向是从程序的执行顺序开始,例如X86平台的启动流程:bootSect.S -> setup.S -> head.S -> main.c的start_kernel()。横向则按照功能模块进行,如单独分析内存管理或进程...

    geekos-0.3.0源代码

    通过阅读源代码,我们可以理解如何分配、回收和保护内存空间。 4. **文件系统(File System)**:虽然GeekOS是一款微型操作系统,但它仍然包含了基本的文件系统支持。源代码中会包含文件的创建、读写和删除操作,...

    jdk 1.6 源代码一

    这些类库是Java程序的基础,通过阅读源代码,我们可以了解到诸如字符串操作、集合框架、I/O流等基本功能的实现原理。 2. **并发编程**:JDK 1.6引入了`java.util.concurrent`包,提供了高级并发工具,如`...

    千年源代码

    2. 分析源码:逐个阅读源代码文件,理解其编程语言、函数和类的定义,以及整体的架构和流程。 3. 跟踪历史:如果源代码附带了版本控制信息(如Git提交历史),可以通过这些信息追溯代码的发展历程。 4. 文档研究:...

    教你如何读懂源代码.zip

    首先,阅读源代码的基础是掌握编程语言。源代码通常是用C++、Java、Python、JavaScript等编程语言编写的。每种语言有自己的语法和语义,如变量声明、控制结构(如if语句和循环)、函数定义等。你需要了解这些基本...

Global site tag (gtag.js) - Google Analytics