`
lxy2330
  • 浏览: 468516 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

读源码的建议

    博客分类:
  • java
 
阅读更多
才在论坛不经意间,看到有关源码阅读的帖子。回想自己前几年,阅读源码那种兴奋和成就感(1),不禁又有一种激动。
源码阅读,我觉得最核心有三点:技术基础+强烈的求知欲+耐心。

说到技术基础,我打个比方吧,如果你从来没有学过Java,或是任何一门编程语言如C++,一开始去啃《Core Java》,你是很难从中吸收到营养的,特别是《深入Java虚拟机》这类书,别人觉得好,未必适合现在的你。
虽然Tomcat的源码很漂亮,但我绝不建议你一开始就读它。我文中会专门谈到这个,暂时不展开。

强烈的求知欲,我认为是阅读源码的最核心驱动力。我见到绝大多数程序员,对学习的态度,基本上就是这几个层次(很偏激哦):
1、只关注项目本身,不懂就baidu一下。
2、除了做好项目,还会阅读和项目有关的技术书籍,看wikipedia。
3、除了阅读和项目相关的书外,还会阅读IT行业的书,比如学Java时,还会去了解函数语言,如LISP。
4、找一些开源项目看看,大量试用第三方框架,还会写写demo。
5、阅读基础框架、J2EE规范、Debug服务器内核。

大多数程序都是第1种,到第5种不光需要浓厚的兴趣,还需要勇气:我能读懂吗?其实,你能够读懂的。

耐心,真的很重要。因为你极少看到阅读源码的指导性文章或书籍,也没有人要求或建议你读。你读的过程中经常会卡住,而一卡主可能就陷进了迷宫。这时,你需要做的,可能是暂时中断一下,再从外围看看它:如API结构、框架的设计图。

我就说说如何读Java源码,以及我曾经的阅读感悟。

Java源码初接触
如果你进行过一年左右的开发,喜欢用eclipse的debug功能。好了,你现在就有阅读源码的技术基础。
我建议从JDK源码开始读起,这个直接和eclipse集成,不需要任何配置。

可以从JDK的工具包开始,也就是我们学的《数据结构和算法》Java版,如List接口和ArrayList、LinkedList实现,HashMap和TreeMap等。这些数据结构里也涉及到排序等算法,一举两得。
面试时,考官总喜欢问ArrayList和Vector的区别,你花10分钟读读源码,估计一辈子都忘不了。

然后是core包,也就是String、StringBuffer等。
如果你有一定的Java IO基础,那么不妨读读FileReader等类。我建议大家看看《Java In A Nutshell》,里面有整个Java IO的架构图。Java IO类库,如果不理解其各接口和继承关系,则阅读始终是一头雾水。
Java IO 包,我认为是对继承和接口运用得最优雅的案例。如果你将来做架构师,你一定会经常和它打交道,如项目中部署和配置相关的核心类开发。

读这些源码时,只需要读懂一些核心类即可,如和ArrayList类似的二三十个类,对于每一个类,也不一定要每个方法都读懂。像String有些方法已经到虚拟机层了(native方法),如hashCode方法。

当然,如果有兴趣,可以对照看看JRockit的源码,同一套API,两种实现,很有意思的。
如果你再想钻的话,不妨看看针对虚拟机的那套代码,如System ClassLoader的原理,它不在JDK包里,JDK是基于它的。JDK的源码Zip包只有10来M,它像是有50来M,Sun公司有下载的,不过很隐秘。我曾经为自己找到、读过它很兴奋了一阵。

Java Web开发源码
在阅读Tomcat等源码前,一定要有一定的积累。我的切实体会,也可以说是比较好的阶梯是:
1、写过一些Servlet和JSP代码。注意,不是用什么Struts,它是很难接触到Servlet精髓的。用好Struts只是皮毛。
2、看过《Servlet和JSP核心编程》
3、看过Sun公司的Servlet规范
4、看过http协议的rfc,debug过http的数据包
如果有以上基础,我也不建议你开始读Tomcat源码。我建议你在阅读Tomcat源码前,读过Struts源码,Struts源码比WebWork要简单得多。这个框架是可以100%读懂的,至少WebWork我没有100%读懂。我曾经因为读懂了Struts源码,自己写过一个Web框架。

当然,在读Struts框架前,最好看过它的MailReader等demo,非常非常不错的。
如果你做过一些Struts项目,那么读它时就更得心应手了。
在读Struts前,建议看看mvnforum的源码,它部分实现了Struts的功能,虽然这个BBS做得不敢恭维。

如果你读过Struts,再开始考虑Tomcat源码阅读吧。
不过,我还是不建议直接读它,先读读onJava网站上的系列文章《How Tomcat Works》吧,它才是Tomcat的最最简易版。它告诉你HttpServletRequest如何在容器内部实现的,Tomcat如何通过Socket来接受外面的请求,你的Servlet代码如何被Tomcat容器调用的(回调)。
学习JSP,一定要研读容器将JSP编译后的Servlet源码。
为什么我总是称呼Tomcat为容器,而不是服务器?这个疑问留给大家吧。

如果你一定要读Tomcat,那么就读Jetty吧。至少它是嵌入式,可以直接在eclispe里面设置断点debug。虽然Tomcat也有嵌入式版本。

Java数据库源码阅读
我建议,先读读Sun的JDBC规范。
我想你一定写过JDBC的代码,那么这时候可以开始阅读源码了。
如果了解JDBC规范(接口),那么它的实现,JDBC Driver就一定要开始了解,我的建议是,读读mysql的jdbc驱动,因为它开源、设计优雅。在读mysql的JDBC驱动源码时,建议看看mysql的内幕,官方正好有本书,《Mysql Internals》,我五年前读过一部分。比如你可以知道mysql的JDBC驱动,如何通过socket数据包(connect、query),给这个C++开发的mysql服务器交互的。

通过上面的阅读,你可以知道,你的业务代码、JDBC规范、JDBC驱动、以及数据库,它们是如何一起协作的。
如果你了解这些内幕,那么你再学习Hibernate、iBatis等持久化框架时,就会得心应手的。

读过JDBC驱动,那么下一步一定要读读数据库了。而正好有一个强大的数据库是用Java开发的,Hsqldb。它是嵌入式数据库,比如用在桌面客户端软件里,如Mail Client。
我四年前为此写过一篇小文,就不介绍了。

Java通讯及客户端软件
我强烈推荐即时通讯软件wildfire和Spark。你可以把wildfire理解成MSN服务器,Spark理解成MSN客户端。它们是通过XMPP协议通讯的。
我曾经在一个项目中,定制过Spark,当然也包括服务端的一些改动。所以它们的源码我都读过。
我之所以推荐它们。是因为:
1、XMPP够轻量级,好理解
2、学习Socket通讯实现,特别是C/S架构设计
3、模块化设计。它们都是基于module的,你既可以了解模块化架构,还可以了解模块化的技术支撑:Java虚拟机的ClassLoader的应用场景。
4、Event Driven架构。虽然GUI都是Event驱动的,但Spark的设计尤其优雅

这么说吧,读它们的源码,你会为做一名程序员而自豪,因为无论是他们的架构设计还是代码,都太漂亮了。

Java企业级应用
当然了,就是Hibernate、Spring这类框架。
在读Spring源码前,一定要先看看Rod Johnson写的那边《J2EE Design and Development》,它是Spring的设计思路。注意,不是中文版,中文版完全被糟蹋了。
在读Hibernate源码前,一定要读读Gavin King写的那本《Hibernate in Action》,同时,应该再读读Martin Fowler写的《企业应用架构模式》,它专门谈到持久化框架的设计思路。当你觉得这两本书读透了,再去看它们源码吧。
而且,在读源码前,你会发现它们用到很多第三方Jar包,二三十个,你最好把那些Jar包先一个个搞明白。

说到企业应用,一定会涉及到工作流。我当年读过jBPM的源码,网上有介绍jBPM内核的文章(银狐)。我感觉它的内核也就两千行,不要害怕。我曾经阅读jBPM源码的博客。
当然了,读工作流源码,前提是一定要对其理论模型有深入的了解,以及写过一些demo、或做过一些项目。

我上面介绍的这些,是我自己读过的,也适合一般人阅读。
我也读过一些非Java源码,感觉不错,也推荐给大家:
dojo源码 它的架构设计得很优雅,仿Java的import和extends。但实际应用起来一塌糊涂。我们当年基于这个开发了自己的框架,不过我不是主力。

Flex源码 Flex 08年底刚刚开源后,我就用它做过一个中型项目,应该说是国内的技术先行者。当时市面没有有深度的书,也没有开源项目。我纯粹是看Flex的Help文档和源码,把项目搞定的。两三年过去了,现在觉得系统设计得蛮优雅的。

好了,先介绍到这里。
上面说到的这些Java源码,我都是4年前、甚至更早读过的。技术变化这么快,像互联网的高速发展,催生很多高性能、分布式数据库,如hadoop。我一看,发现自己已经落伍了。
这几年,想必已经出现了很多优秀的框架,大家不妨分享出来。


题后记
这三年,一直在创业,主要是技术应用,偏业务,源码阅读不多,但很欣赏那些专注于技术的狂热者。
现暂别创业,进入一家电子商务公司,负责其B2C网站的改版和运营。
(广告)如果你对技术、对高负载的大型B2C开发也情有独钟,不妨看看这里。


分享到:
评论

相关推荐

    dubbo源码解析

    17. 读源码建议:文章给出了阅读Dubbo源码的一些建议,特别是对于初学者,需要有以上的基础知识和经验储备,才能更好地理解和消化源码内容。 综上所述,阅读和理解Dubbo源码需要较为扎实的Java基础和丰富的框架应用...

    易语言对象读网页源码.rar

    《易语言对象读网页源码》 在编程领域,易语言是一种独特的中文编程语言,它以其易学易用的特点受到广大编程爱好者的...因此,建议大家认真研究"易语言对象读网页源码.rar"中的内容,不断实践,提升自己的编程水平。

    易语言源码应用程序图标修改器源码.rar

    在学习过程中,建议动手修改源码并运行,观察不同改动带来的效果,以加深理解和实践能力。同时,配合查阅易语言的官方文档和社区资源,可以更全面地掌握易语言的特性和技巧。 总的来说,《易语言源码应用程序图标...

    微信小程序淘票票小程序源码(源码+源码导入视频教程+源码导入文档教程)小程序精选源码亲测可用

    6. **小程序精选源码**:这里的“精选”意味着这套源码被选为高质量的示例,可能是由于其功能完善、代码结构清晰或者易读性好,可以作为学习和参考的标准。 通过这个压缩包,学习者不仅可以获得一个实际的项目实例...

    爱读书图书管理源码

    爱读书图书管理源码 介绍 一个简单的图书管理程序,可以浏览图书并添加借阅图书。 通过还书阁退还借阅的图书。留言版块可以交流回复留言。 后台管理已有的功能。 图书管理系统使用说明 1、用户登录图书馆管理...

    网上找的android互相之间远程控制的源码

    在Android平台上实现设备之间的远程控制是一项技术挑战,但也是一个极具实用性的功能,尤其对于开发者和IT专业人士来说。...不过,由于源码阅读需要一定的基础,建议具备扎实的Java和Android开发经验后再进行研究。

    语音验证码接口源码 ZTSpeechVerificationInterface.rar

    系统设置:号码分流 签名设置 生日提醒 公告管理 留言建议 屏蔽词管理 短信报表 短信服务 免费对接咨询,有任何问题都可以找我,对接使用的接口语音很多,满足一切,不收钱 三、注意事项 1、开发语言:PHP,无...

    源码追踪经验谈(侯俊杰谈如何读代码)

    如果源码没有注释,侯俊杰可能建议我们自己添加注释,这既是理解过程,也是知识整理的过程。 面对别人写的代码,有时需要具备一定的心理学洞察。理解作者的设计意图,考虑他们在特定情境下的选择,可以帮助我们更好...

    易语言源码易语言IE修改迷源码.rar

    如果你打算学习并使用这些源码,建议先在易语言环境中创建一个项目,逐步理解和重构代码,以便更好地掌握其工作原理。 总的来说,"易语言IE修改迷源码.rar"提供了一个学习易语言编程和浏览器定制化改造的机会。通过...

    易语言驱动级读写内存模块源码

    在IT领域,驱动级编程是一种深入操作系统内核的...如果想要深入学习这方面的知识,建议首先熟悉易语言的基础语法,然后逐步理解并实践这个源码,最后结合Windows驱动开发的相关书籍和文档,以全面掌握驱动级编程技术。

    史上最全的Java源码学习资料,全是干货,建议先收藏再学习

    我们需要知道为什么要读源码,例如,理解框架解决的问题,比较与同类框架的优劣,这样有助于我们深入理解其设计意图。同时,不要忽视注释,它们是理解代码逻辑、异常情况的关键。源码的逻辑顺序反映了作者的设计思路...

    豆瓣图书搜索阅读微信读书程序源码.zip

    6. 搜索模块:实现图书的关键词搜索,可能包含搜索建议和模糊匹配功能。 7. 阅读模块:加载和展示电子书内容,可能包含翻页效果、字体设置等。 开发者在编写此类程序时,需要考虑性能优化、用户体验设计、数据安全...

    读文件扇区数据的源码简洁版

    "读文件扇区数据的源码简洁版"这个主题,涉及到计算机存储的基本概念,包括扇区(sector)、文件系统以及如何通过编程语言进行磁盘I/O操作。下面我们将深入探讨这些知识点。 首先,我们需要理解什么是扇区。扇区是...

    易语言学习进阶读字段值源码

    在实际学习过程中,建议先尝试理解每段代码的功能,然后逐步分析实现细节。如果遇到不懂的概念或语法,可以查阅易语言的相关文档或在线教程。同时,尝试自己动手修改和运行代码,实践是最好的老师,这将加深你对...

    在线帮助系统源码文件

    5. **用户反馈**:在线帮助系统通常集成用户反馈功能,允许用户提交问题、建议或者对现有帮助内容的评价,以便管理员收集改进意见。 6. **版本控制**:随着产品的迭代更新,帮助系统也需要同步更新。版本控制功能...

    51单片机源码

    C语言具有易读性强、可移植性好等优点,适合编写复杂的控制逻辑;而汇编语言则可以直接对硬件进行操作,效率更高,但编写起来较为复杂。本压缩包中的源码可能涵盖了这两种语言,通过研究这些源码,我们可以了解不同...

    MAPX开发GIS车载系统源码

    源码中可能会有处理GPS NMEA数据的模块,将这些数据转换为可读的地理坐标。 此外,交互设计也是GIS车载系统的重要部分。用户界面需要清晰、直观,便于驾驶员操作。源码可能包含事件处理机制,如点击地图上的兴趣点...

    tidy所有源码,用于正文提取

    在阅读和分析tidy源码时,建议遵循以下步骤: 1. 阅读源码的主入口点,理解tidy如何启动和执行。 2. 分析解析器模块,了解HTML解析的基本流程。 3. 研究错误检测和修复机制,看看tidy是如何识别和解决HTML错误的。 ...

    软件源码及分析器大包.rar

    首先,软件源码是程序设计的基础,它是程序员用编程语言编写的可读指令,用于控制计算机执行特定任务。源码是软件的核心,通过阅读源码,我们可以了解软件的设计思路、算法实现以及功能结构。这对于学习新语言、研究...

    Python自动选股系统源码.zip

    Python因其丰富的库和易读性,成为数据科学和金融分析的首选语言。例如,Pandas库用于数据处理和分析,Numpy用于数值计算,Matplotlib和Seaborn用于数据可视化,而Scikit-learn则提供了机器学习算法。 在...

Global site tag (gtag.js) - Google Analytics