`
xiangxingchina
  • 浏览: 520011 次
  • 性别: 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的配置,还不如了解其思想,当你拥有了足够多的思想时,学习新的框架就会更简单,因为你会觉得"要是是我,我一定会这样处理",结果作者果然就是如你所然,这其实就是规则一。
对刚进公司的新人也是一样,组长给你一个项目代码,让你自己看,也许有些过时的文档;你会非常头大,组长说"你有问题来问我。"经验告诉我,你其实有问题但是都不知道该怎么问。所以你可以依据以上规则,静下心来,耐心的调试,分析,总结,记得要记笔记。不断的假设、猜想,然后证实、证伪。终于你发现,原来是这样,也没想的那么难。
分享到:
评论

相关推荐

    ASP.NET客户关系管理系统的实现(论文+源代码+文献综述+外文翻译+答辩PPT).zip

    源代码部分展示了如何使用ASP.NET的Web Forms或MVC模式来构建Web界面,以及如何与数据库进行交互。可能使用了C#作为后端语言,利用ADO.NET或Entity Framework进行数据操作。此外,还可能运用了JavaScript、jQuery和...

    Java 精讲代码 张孝祥老师的经典代码

    在Java编程领域,张孝祥老师是一位备受尊重的专家,他的教学材料往往富含深度与实践...在实际学习过程中,应仔细阅读和分析每段代码,理解背后的思路,并尝试将其应用到自己的项目中,这样才能真正吸收并掌握这些知识。

    c语言学习中的精华!!!

    6. **预处理器**:预处理器指令(如#include、#define、#ifdef等)用于在编译阶段处理源代码,理解它们的作用可以帮助我们更好地组织代码和实现宏定义。 7. **内存管理**:了解栈和堆的区别,以及如何使用malloc和...

    编程珠玑第二版英文版 带源码

    《编程珠玑第二版英文版》是一本深受程序员喜爱的经典著作,由Jon Bentley 所著。这本书以其深入浅出的方式...同时,结合提供的源代码,读者可以亲自实践,将理论知识转化为实际操作能力,从而更好地吸收书中的精华。

    程序员两年的积累

    【标签】"源码"提示我们,作者可能深入研究过某些开源项目的源代码,例如Java的Spring框架、Python的Django框架,或者JavaScript的React库等。通过源码阅读,可以学习到如何设计高效的数据结构,理解模块化、面向...

    58同城开源框架

    开源框架是指遵循特定开放源代码许可协议的软件框架,允许用户自由地使用、修改和分发源代码。58同城开源框架的开放性使得开发者可以深入理解其内部机制,根据自身需求进行定制,同时也能贡献自己的代码,推动框架的...

    最全的java源码库

    Java源码库是一个极其宝贵的资源,对于学习和深入理解Java编程语言至关重要。这个"最全的java源码库"包含了广泛且...在学习过程中,建议结合相关书籍和文档,理论与实践相结合,这样才能真正理解和吸收源码中的精华。

    RationalEdge:OpenUP精华OpenUPInaNutshell

    EPF是一个开放源代码项目,专注于软件开发过程和方法论的研究与创新。通过EPF平台,OpenUP得以吸收来自不同领域和背景的专业知识,形成了一个更加成熟和完善的过程模型。 #### OpenUP的特点 - **精益与迭代**: ...

    162100(简洁论坛/分类信息/文章发布)多用系统 v1.8

    至于文件"code",这可能是源代码的压缩包,包含了系统的所有源文件,开发者或管理员可以通过解压并浏览这些文件来了解系统内部的工作原理,进行定制化开发或调试。 总的来说,"162100(简洁论坛/分类信息/文章发布)...

    TSL-TGE-开源

    TSL-TGE的开源特性意味着其源代码对公众开放,任何人都可以查看、使用、修改和分发。这为开发者提供了一个灵活的平台,可以根据项目需求进行定制,或者贡献自己的改进和扩展。开源社区的力量也使得这个项目能够持续...

    FutureBSD-开源

    在开源软件的世界中,"FutureBSD-开源"体现了开放源代码的核心理念,即透明度、协作和自由。开发者可以自由地查看、修改和分发代码,这种开放的环境鼓励了技术的进步和社区的繁荣。通过这样的方式,项目可以汇聚来自...

    3D - Knot Simulator-开源

    在开源软件的世界里,3D结模拟器展现了开放源代码的优势。开源意味着代码对所有人开放,开发者可以自由地查看、修改和分发代码,促进软件的不断优化和创新。这种模式鼓励社区参与,使得软件能够吸收更多用户的智慧,...

    minim:一种编程语言

    在压缩包"minim-master"中,包含了Minim语言的源代码、文档、示例以及可能的开发工具。这些资源对于深入了解Minim,甚至参与到它的开发中来,都是非常宝贵的。 总的来说,Minim是一种致力于提高开发效率和学习体验...

Global site tag (gtag.js) - Google Analytics