前言
有一段时间,我觉着我非要阅读开源项目的源码不可。
那时,我在公司负责设计和开发了很多系统。如果连大学时带领大家开发和维护学校网站也算上的话,那我进行软件开发已经整整十年了。在这十年里,我对自己设计和开发的系统都很有信心,但有一个疑惑一直萦绕在我心头:我不知道,我的架构和世界最优良架构之间的差距到底有多大。
阅读开源项目的源码能给我答案。
许多优秀的开源项目历经数千名开发者的数万次提交,被数亿用户使用。这些项目从可扩展性、可靠性和可用性等各个角度考量,都是十分优良的。通过阅读这些项目的源码,我能找到自己在软件设计和开发上的不足。
于是我开始了我的源码阅读计划。
在阅读源码的过程中,我看过不少资料。但很多资料对源码中简单的部分讲解得细致入微,而对复杂的部分则避而不谈或含糊其辞。在阅读源码的过程中,我也走过不少弯路,经常在一个难点中挣扎很久不能前进。
当然,阅读源码也让我收获颇丰。它不仅让我知道了自己的设计与优良设计之间的差距,还让我学到了许多架构技巧和编程知识。在源码阅读的过程中,我也总结出了许多经验和方法。因此,我决定写这本书,将经验和方法分享出来,指引许多和我一样前行在源码阅读道路上的人。
源码阅读首先要选定相应的源码作为材料。从项目的成熟度、涉及面、应用广度、项目规模等多方面考虑,本书最终选中 MyBatis源码。因此,本书将以阅读 MyBatis源码为例,介绍源码阅读的经验和方法。
在本书的写作中,我努力做到详尽而不啰唆。本书以包为单位,对 MyBatis源码中的 300多个类进行了介绍。在此过程中,对于简单或重复的类一笔带过,但对于复杂的类,则是逐方法、逐行地进行分析,力求让大家读得顺、读得懂、有收获。
本书分为五篇,各篇主要内容如下。
第1篇为背景介绍,包括第1~4章。
第1章介绍了源码阅读的意义和方法。
第2章对 MyBatis的背景和快速上手方法进行了介绍。这一章的内容是简单但重要的。对于任何一个软件,其背景对应于软件的“设计需求”,其使用对应于软件的“主要功能”。把握一个软件的设计需求和主要功能对于阅读软件的源码很有帮助。
第3章中使用断点调试方法对 MyBatis的执行过程进行了追踪。该章内容有助于我们了解整个 MyBatis的内部框架。
第4章对 MyBatis源码结构进行了介绍,并根据源码包的功能对包进行了分类。
第2篇为基础功能包源码阅读,包括第5~11章。
在这一篇中,我们对基础功能包中的源码进行了阅读。基础功能包相对独立,与 MyBatis的核心逻辑耦合小,比较适合作为源码阅读的切入点。在阅读这些源码时,我们也会逐步介绍一些阅读源码常用的方法和技巧。
第5章介绍了 exceptions包的源码,可以通过该包了解 MyBatis的整个异常体系。
第6章介绍了 reflection包的源码。该包基于反射提供了创建对象、修改对象属性、调用对象方法等功能。这些功能在 MyBatis的参数处理、结果处理等环节都发挥了重要的作用。
第7章介绍了 annotations包与 lang包的源码。这两个包中全是注解类。我们将通过对 Java注解的学习详细了解每个注解类的含义。最后,我们还通过源码分析了注解类如何在 MyBatis的运行中发挥作用。
第8章介绍了 type包的源码。通过这一章将了解 MyBatis如何组织和实现类型处理器,以完成对各种类型数据的处理。
第9章介绍了 io包的源码。通过该包将了解到 MyBatis如何完成外部类的筛选和载入。
第10章介绍了 logging包的源码。logging包不仅为 MyBatis提供了日志记录功能,还提供了获取和记录 JDBC中日志的功能。通过这一章将了解这些功能的实现细节。
第11章介绍了 parsing包的源码。通过这一章将了解 MyBatis如何完成 XML文件的解析。
第3篇为配置解析包源码阅读,包括第12~17章。
第12 章介绍了配置解析相关类的分类方法。配置解析相关类可以按照类的功能划分为解析器类和解析实体类。
第13章介绍了 binding包的源码。该包负责将 SQL语句接入映射接口。
第14章介绍了 builder包的源码。该包中的建造者基类和工具类为 MyBatis基于建造者模式建造对象提供了基础。此外,该包还完成了 XML文件和注解映射的解析工作。
第15章介绍了 mapping包的源码。该包完成了 SQL语句的处理、输入参数的处理、输出结果的处理等功能,并为 MyBatis提供了多数据库支持的能力。
第16章介绍了 scripting包的源码。就是在这个包中,复杂的 SQL节点被逐步解析为纯粹的 SQL语句,该章将详细讲解这一解析过程。
第17章介绍了 datasource包的源码。该包包含了 MyBatis中与数据源相关的类,包括非池化数据源、池化数据源、数据源工厂等。也正是通过该包,MyBatis完成了和数据库的对接。
第4篇为核心操作包源码阅读,包括第18~24章。
在这一篇中,将详细介绍 MyBatis的核心操作包。
第18章介绍了 jdbc包的源码。该包仅使用六个类便为 MyBatis提供了运行 SQL语句和脚本的能力。
第19章介绍了 cache包的源码。该包向我们展示了 MyBatis如何使用装饰器模式为用户提供丰富的、可配置的缓存,并且该章还从功能维度出发详细介绍了 MyBatis的两级缓存机制。
第20章介绍了 transaction包的源码。该包为 MyBatis提供了内部和外部的事务支持。
第21章介绍了 cursor包的源码。通过该包,MyBatis能将查询结果封装为游标形式返回。
第22章介绍了 executor包的源码。executor包是 MyBatis中最为重要也是最复杂的包。在这一章中,首先,以子包为单位分别介绍了 MyBatis的主键自增功能、懒加载功能、语句处理功能、参数处理功能、结果处理功能和结果集处理功能。然后,在此基础上对 MyBatis中执行器的源码进行了阅读。最后,阅读了 MyBatis中错误上下文的源码,了解 MyBatis如何及时地保留错误发生时的现场环境。
第23章介绍了 session包的源码。session包是一个对外接口包,是用户在使用 MyBatis时接触最多的包。
第24 章介绍了 plugin 包的源码。在该章中我们编写了一个插件,然后通过源码详细了解了 MyBatis插件的实现原理及 MyBatis插件平台的架构。
第5篇为总结与展望,包括第25、26章。
第25章对阅读 MyBatis源码过程中的方法和技巧进行了总结。
第26 章从项目的成熟度、涉及面、应用广度和规模等角度综合考量,为大家推荐了一些优秀的开源项目。学习完本书后,大家可以从这些项目中挑选一些进行源码阅读。
源码阅读毕竟是一个对知识广度和深度都有较高要求的工作,为了大家能够顺利地阅读MyBatis的源码,我们会在很多章节之前先介绍该章节源码涉及的基础知识。掌握这些基础知识后再阅读相关源码则会轻松很多。
受篇幅所限,书中只能给出部分 MyBatis源码。我们将完整的带中文注释的 MyBatis源码整理成了开源项目,供大家下载与参考。该项目的地址为:https://github.com/yeecode/MyBatisCN。
为了让大家能更轻松地理解和掌握一些相对复杂的知识点,我们还准备了许多示例项目。下载地址为:https://github.com/yeecode/MyBatisDemo。
由于时间和水平有限,书中难免会有疏漏之处。您可以通过我的个人主页与我取得联系并进行交流,在那里也能看到我的最新项目。我的个人主页地址为:http://yeecode.top。
通过阅读本书,您将详细了解 MyBatis中每一个类的结构、原理和细节。但要注意,这只是我们阅读本书的额外收获。掌握源码阅读的方法和技巧,并将这些方法和技巧应用到其他项目的源码阅读工作、系统设计工作、软件开发工作中,这才是阅读本书的最终目的。
源码阅读是一项过程艰苦而结果可观的工作。每一个潜心阅读源码的开发者都值得尊敬,也希望本书能够在您阅读源码的过程中为您提供一些帮助,让您多一些收获。
加油!奋斗路上的你和我。
著者