基于《C++那些事》交流群大众反馈,同时针对自己学习过程中的一些问题,做一些记录性的分享。
本节主要是分享自己的实习期间如何快速阅读一些源代码,以及快速阅读一些开源库。
在我自己的开发过程中,主要围绕以下三点展开:
-
项目的业务/开源项目主要做什么
-
目标的建立
-
系统的学习
不管是实习期间的代码还是开源项目,例如;STL这种代码,一般代码量不少,如何快速的抓住重点变得非常重要,本文接下来围绕上述三点展开。
1.做什么
首先你得明确自己拿到该开源项目,主要目的是做什么,一般无非两点:
-
速成般的使用
-
科研般的研究
如果重点是放在第一点,那么重点是使用,我们不需要它的实现细节,只需要把握一些关键的点,例如:像TinyXml、RapidJson这种开源项目,快速上手及使用还是比较简单,而源代码也是非常的少,这里有个建议:使用自己比较擅长的IDE来看源代码,这样后续会方便很多,无论是打断点,还是函数之间的跳转,算是效率的提升吧。
针对使用的基础之上,例如:我想研究priority_queue在STL库中的实现,怎么快速抓住重点进行研究呢?
基于测试般的学习,如下五点:0.下载源代码,导入IDE 1.编写测试用例,主调自己想考虑的函数 2.梳理类与类之间的继承关系 3.剖析自己代码的版本,例如:C++11特性这些语法的总结 4.一些奇奇怪怪的点,但是又不影响主逻辑
这里还是以实际例子说明,在STL中很多人对大根堆与小根堆如何构建非常迷茫,在我看来,无非重点是比较的意义。下面解释为啥说了比较的意义这个重点。
在priority_queue以及map等代码内容的一些实现中,非常重要的一点是Cmp,也就是比较器,或者说两个对象比较的实现手段,而决定大根堆与小根堆的设计原则在于是大于号代表大根堆,还是重载小于号决定小根堆。使用默认的greater代表大根堆,还是使用less代表大根堆,这些都是疑问,带着这些疑问及测试用例调用函数逻辑来一步步的解答疑惑。
在基于IDE的基础,我们可以在调用函数之处,打上断点,一步步的运行,看看堆栈信息,有利于我们理解程序的运行轨迹。
在像C++源代码中,大部分是以类来封装,我们就需要熟悉类的特性,以及继承、多态等的基础知识,所以说读源代码对于学习一门语言来说是非常有帮助的,你可以review别人的代码同时,记录下;类与类之间的继承关系,梳理调用关系!
在最新的代码当中,部分及全部支持C++11以上的特性的代码,需要懂一些新特性的语法知识,对于不懂之处,记录一些关键字及代码行数,文件行数,边review,边检索相关知识,填补漏洞。
最后,便是一些比较奇怪的点,在像STL这种源代码中,会有一些奇能淫巧,不要方,先记录下来,直接搜就完事了,一般是可以找到解答的,推荐stackflow上搜。例如:EBO,namespace之间的识别顺序等等,看似奇怪的代码,实际上内含很多知识点。
当然,上面只提到了开源项目的解决方案,针对业务代码,关键点在于快速的抓住要改动的代码位置以及代码逻辑,而一般自己交接的代码是在某个特定的框架内部进行改动业务逻辑,这便会非常简单只需要从下面几点来:
-
框架主逻辑
-
业务的关键字段
-
业务函数入口
快速打破僵局的点在于熟悉框架,入口在哪里,随后根据产品的需求来定位关键字段,全局的有策略的检测,如果还是不懂,就请教负责该项目的人,来咨询相关的业务逻辑,非常复杂的先把业务函数与框架区分开,从框架逻辑走位到业务函数即可。
2.目标的建立
明确了所做的事,需要给自己设定一个开发的目标或者说读完源码后的目标,进而促进自己不断的深入下去,学习更多的技术点。
例如:STL当中的萃取机是一个技术点,在各个数据结构当中又是怎么使用的,各个对外的一些函数接口的底层实现逻辑是什么。
在1中实际上明确了要做什么,此时是不方的,至少不会被源码劝退!明确自己当前的目标,一点点来就行了。
3.系统的学习
最后便是,系统的梳理一遍之前学习的点,将其串起来,例如:TinyXMl这种库代码非常少,从局部以点带面的形式扩散开来,到最后实际上看的东西不多了,在下次碰到源码的时候不会那么捉急,实际上这也是经验的积累过程,一开始从小的代码库,再到大的代码库。
4.开源项目的推荐
TinyXml、RapidJson、libco、STL等这些源码,如果你是C++爱好者可以深入研究一番,还是有点技术含量的,如果你有这专业的领域,例如:做图像,那么看opencv这种,可以研究一番,专业领域专业的事,从源代码看起,大家加油~
本节完