今天在微博上看到庄表伟在知呼上回答的如何更有效地学习开源项目的代码?
我很认同他总结的 “学习开源,就尽可能在代码里找答案,而不是在代码之外找答案,那些都是二手的,而且很可能是不准确的。” 但是如何读好,读懂代码,我这边还是有不同的认识。
1. 需要从代码管理库下载完整的源代码,而不是简单的源代码文件包或者source.jar.
这样做有很多好处,一个是你可以获取代码的修改记录,还有你可以获取到完整的测试代码,当你要提交patch的时候,你可以借助版本管理工具生成针对不同版本的patch。
2. 示例代码与单元测试
示例代码可以帮助你学会使用相关开源项目的API。很多朋友在使用开源项目的时候遇到一个小问题就发信给开发者要这样或者那样的示例代码,其实他们没有发现大部分的开源项目在开发的过程中,为了验证其实现的功能,都会写很多单元测试代码。这些代码其实非常好的示例代码。可能是下源码,建工程会花费你几个小时的时间,但是如果你想深入了解开源项目的话,这点投资还是很有价值的。
其实读单元测试的好处太多了,这里简单给大家列一下:
- 由于一个单元测试一般也就是几个小时的开发工作量,你很容易就能读懂相关的代码。
- 每个单元测试都是可以独立运行的,这样节省你跟踪调试的时间。
- 单元测试在很大程度定义了软件的功能,可以帮助你快速掌握项目的相关API。
- 如果你修改的开源项目的代码,你可以通过修改单元测试来验证你的修改是否正确。
3. 架构文档
其实大部分的开源项目都会对其架构有一定的描述,这些描述可能会有点过时,但是通读一下会让你项目有一个比较深入的认识。这样做好比是让你对北京的二环,三环,四环,五环有个大体的认识。这样在你要对代码的某块内容进行详细研究的时候(例如找中关村的位置的时候,知道西北四环)就能很快定位了。
分享到:
相关推荐
0615_极智开发_解读github参与开源项目代码pr的方法
阅读代码学习过程中,添加部分中文注释的代码
以下是根据标题“Python开源项目汇总”和描述中的信息,对2017年30个惊艳的Python开源项目进行的详细解读。 1. 数据分析与科学计算: - Pandas:强大的数据结构和数据分析工具,适用于快速、灵活地处理大型数据集...
微信小程序开源项目库汇总是一个非常宝贵的资源集合,它聚焦于JavaScript开发中的微信小程序应用。这个压缩包文件"awesome-github-wechat-weapp-master"显然包含了大量在GitHub上活跃的、由社区贡献的微信小程序项目...
【压缩包子文件的文件名称列表】:未提供具体的文件名,但根据常见的开源项目结构,我们可以推测可能包含以下部分: 1. HTML文件:游戏的界面结构,使用HTML5标签构建。 2. CSS文件:包含游戏的样式规则,如角色、...
课程分享——深度学习经典论文与开源项目实战,完整版20章,提供全部数据,代码,PPT。 深度学习经典论文解读与项目实战课程旨在帮助同学们掌握当下深度学习领域最核心论文思想及其源码实现。所选论文均是计算机...
今天我们要探讨的是一个名为“ipmsg”的开源项目,它是一款实现即时通讯功能的软件,尤其擅长于文件传输。通过分析其源代码,我们可以深入了解网络通信和TCP协议在实际应用中的工作原理。 首先,ipmsg的全称可能是...
- 开源项目背后有强大的社区支持,用户可以通过论坛、GitHub等平台交流问题,获取帮助,共同推动项目的进步。 综上所述,“Pixhawk源码总结.pdf”这份文档详细介绍了Pixhawk的软件架构、关键算法以及源码解读,...
通过分析这个开源代码,我们可以了解到如何与PLC建立连接,发送和接收数据,以及如何解读和处理这些数据。 源代码中使用的RXTX串口通讯组件是实现与PLC通信的关键。RXTX是一个Java库,用于提供与串行和并行端口进行...
1. **Android源码分析**:开源项目通常会附带完整的源代码,这对于开发者来说是一份宝贵的教材。通过阅读源码,开发者可以了解Android应用的架构设计、模块划分以及如何高效地利用Android SDK。 2. **编程实践**:...
**标题解析:** "ARTNET c# 开源代码" 指的是一个使用C#编程语言编写的开源项目,该项目实现了ARTNET协议,用于控制灯光设备,特别是那些支持DMX512标准的灯光系统。 **描述解读:** 描述中提到的“c# 灯光协议,...
laravel-china_开源项目_phphub5_源代码解读_newphphub5
Eclipse开源项目mywork是一个基于Java的开发平台,包含了多个模块化的工具和应用程序,旨在提供一个集成化的开发环境。这个项目展示了Eclipse平台的强大扩展性和灵活性。以下是对每个子文件的详细解读: 1. **...
作为开源项目,aishraj-vtraceroute欢迎社区成员的贡献,包括提交bug报告、提供建议、改进代码或添加新功能。 总的来说,"aishraj-vtraceroute"项目展示了如何利用Go的高效性和React的灵活性来开发一个实用的网络...
在压缩包中的“GitHub 的开源项目:绝版游戏保护工程.txt”文件,可能包含了项目介绍、游戏列表、参与指南、代码仓库链接以及如何贡献的详细信息。以下是对这个文件内容的详细解读: 1. **项目介绍**:可能详细阐述...
在当今的移动开发领域,Android系统占据着主导地位,而GitHub作为全球最大的开源代码托管平台,聚集了大量的Android开发者和他们的开源项目。这些项目不仅提供了丰富的功能实现,还展示了最新的技术趋势和最佳实践。...
这篇文档将深入解析《android开源项目源码,完整商城项目源码(服务端+客户端)》这一开源资源,包括服务端(ECServer_D)和客户端(ECClient_D)的架构设计、主要功能模块、技术选型及开发文档的解读。 首先,这...
本文将对开源项目维护的要点进行深入解读,着重探讨如何从项目管理的角度出发,进行有效的代码规范、测试、持续集成,以及如何在实际操作中做好配置管理和构建部署。 首先,代码规范是开源项目维护的基础。一个统一...
在信息技术领域,开源项目扮演着至关重要的角色,它们促进了技术创新、代码共享和社区协作。本文将深入探讨一个名为“tcard-valuegraph”的开源项目,它提供了一种通过图形化方式来洞察任何值的强大工具。 “tcard-...