学会读代码

简介:   作为研发人员,阅读别人的代码是一件经常要做的事情。在学习编程语言的时候,也需要通过阅读代码理解语法和语言机制。通过阅读别人的代码,学到自己编写程序的本领,这也是一种极佳的学习方法。有很多公司给实习生的工作安排,就是阅读代码。通过读代码,可以掌握公司的业务,以及生产组织的方法。大学生常说缺乏实践经验,其实阅读程序也是一种积累编程经验的方法。  写程序和写文章可以放在一起类比。写文章需要先从

  作为研发人员,阅读别人的代码是一件经常要做的事情。在学习编程语言的时候,也需要通过阅读代码理解语法和语言机制。通过阅读别人的代码,学到自己编写程序的本领,这也是一种极佳的学习方法。有很多公司给实习生的工作安排,就是阅读代码。通过读代码,可以掌握公司的业务,以及生产组织的方法。大学生常说缺乏实践经验,其实阅读程序也是一种积累编程经验的方法。

  写程序和写文章可以放在一起类比。写文章需要先从宏观入手,构思文章的结构;程序的结构设计好了,程序也差不多能写出来了。一篇好的文章需要各种句式和措辞的合理组合;写程序就是要熟练使用控制结构和语句。但凡文章写得好的人,一定看过很多别人写的文章;同样的道理,多看别人的程序,用心地去看,也可以提高自己写代码的能力。

  从20世纪90年代开始,开源运动为IT业界开创了一个崭新的世界。开源运动奉献出了一大批的优秀项目,为学习者在共享协议框架内免费使用。这为学习者提供了难得的直接观摩成熟项目的机会。甚至于,大学生在校期间就有机会自由加入到开源社区,参与到项目的开发中去。每年的暑假,也有一些组织提供让大学生短期参加开源项目的活动,使在校大学生获得产业一线的指导,获得在大企业实习的机会,当然,还有丰厚的报酬。

  阅读数万行开源软件项目的代码需要不少高级技巧,对初学者有些为时过早,这个可以作为翅膀长硬后的选项。不积跬步,无以致千里,在学习程序设计之初,要意识到读源代码对技术成长的重要意义,尝试从一些小段的代码入手,在阅读中找到有效的阅读程序的方法。

  初学者阅读代码的来源,可以是教科书上的例题,也可以是一些案例集中的程序库,当然也可以是一些已经开发完成的小型项目。

  阅读代码要采用先整体,后局部的方法。在阅读时一头就扎到细节中的做法不可取,容易只见树木不见森林。先对整个程序有个总体的认识,将有助于细节的把握。很多的程序在开始时都会提供注释,对整个程序进行说明,这也是编码规范的要求。如果有注释的话,可以先读到程序的功能是什么,以及程序中主要算法的思想,这些将有助于从整体上把握程序。要先从整体上了解其中各个子程序(函数)的大致功能及调用关系,然后再细读其中的每一个函数。为找出各函数的调用关系,可以从程序执行的入口(对C、C++、Java而言,都是main()函数)开始读,以此找出程序间相互调用、返回的路径。每个函数是程序中相对独立的模块,要先看整体的控制结构,再到具体的语句;先看出解决问题的整体方案,再发现其中的技巧。这种阅读程序的习惯,体现的也是自顶向下的思想,这和设计程序的方法是一致的,体现的就是一种专业的思维模式,在阅读中逐步深化这种思维方式。

  程序的三种控制结构分别是顺序、分支和循环。问初学者哪种结构最复杂时,往往回答是循环。的确,在学习程序设计中,用循环结构解决问题将不少人绕了个够呛。如果需要循环嵌套,那更是不得了的事。设计程序中要自顶向下地分析问题,阅读程序时也是优先成块的整体阅读。从这种角度,先能看到由顺序结构形成的大块,然后再关注用逻辑更为复杂的分支和循环描述的细节,体现出来的是对顺序结构的重视。从这个角度,简单的顺序结构竟包含着守拙中的极巧,体现的是“大道至简”。

  在编程时,在需要的地方写上注释是良好编码风格的要求。在阅读不熟悉的程序时,尤其是代码量比较大的程序,及时、准确地加上你自己的注释也是很重要的事。添加注释不限方式,可以在打印稿或者书上写注释;如果阅读的是电子版的代码,直接在编辑器中写上注释。通过写注释,将别人的编程思想及时用自己的话写下来,用“写下来”的这个动作,与代码产生交互,在大脑中留下较为深刻的印象。写注释时也体现先整体再细节的原则,优先对大段功能的注释,然后追求对细节的注释。阅读代码时难免会出现理解上的错误,及时地修改注释,记录下正确理解的历程。写注释还能避免读明白了却后边忘了前边的现象,也可以避免不必要的重复阅读,有助于保证学习效率。

  同一段代码可以有意识地对其反复阅读,这有助于对代码的理解。在第一次阅读代码的时候可以跳过非常多的一时不明白的代码段,只写一些简单的注释或提出问题。在以后的重复阅读过程中,对代码的理解会一次比一次更深刻,及时修改那些注释错误的地方,并且补足上一次没有理解的地方。对一段认为已经理解的代码再重读一次,往往还会发现以前没有注意到的细节。

  阅读程序时。不管程序是否能够运行,要学会“用人脑执行程序”,按照计算机执行程序的步骤去“执行”程序。大脑是CPU,拿张空白纸过来,当作内存,在程序运行过程中产生的各种数据的变化都写到“内存”上去,手、眼、脑并用。这样读程序,是掌握程序中的细节的方法,尤其是当程序中包含复杂的算法时,这更是一种必要且有效的方法。有些复杂的程序,涉及到函数参数传递、数组、指针,写出内存中数据变化的过程,会让程序在大脑中的执行可视化,“纸上谈兵”中,将程序玩弄于股掌之中。

  可以将要阅读的代码先运行起来,先对程序有感性认识,再设法对其进行理性分析。如果阅读的程序本来就是可以执行的,这样做很容易。而如果阅读的程序只是一些独立的函数,可以围绕这些函数编些测试程序,调用要阅读的函数。可以用单步跟踪的方法执行程序,可以理解函数的调用关系和执行流程,开启观察窗口可以获得更多的细节,设置断点提高跟踪的效率,让计算机充分参与、辅助理解程序。



本文来源:《逆袭大学——传给IT学子正能量》一审过后,要压缩篇幅,将整理过的文字登在些处共享。

==================== 迂者 贺利坚 CSDN博客专栏=================

|==  IT学子成长指导专栏  专栏文章分类目录(不定期更新)    ==|

|== C++ 课堂在线专栏   贺利坚课程教学链接(分课程年级)   ==|

======== 为IT菜鸟起飞铺跑道,和学生一起享受快乐和激情的大学 =======


目录
相关文章
|
6月前
|
算法 前端开发
可以读通讯稿的组数
可以读通讯稿的组数
43 0
|
6月前
读操作
读操作
36 0
|
6月前
|
编解码 计算机视觉
读、写视频
【5月更文挑战第7天】读、写视频。
46 2
|
6月前
读取数值
读取数值。
39 5
|
程序员
读《第一次把事情做对》有感
上班的时候,领导在群里发了一个 PDF 书籍《第一次把事情做对》,被这个书籍名称吸引住了,因为作为程序员每天有开发新任务,解决旧任务的 BUG,第一次就把事情做的完全正确几乎不可能呀,觉得很有看的必要,这个简单读了一下,跟大家分享一些文中要点。
120 0
|
关系型数据库 MySQL
幻读“异常”引出的快照读创建点问题
幻读“异常”引出的快照读创建点问题
|
C# 开发者
《编写高质量C#代码的50条有效方法》| 每日读本书
想成为一名高级的的.NET开发者需要深度理解C#编程语言所必需的Effective影印版系列书籍之一。此外本书的在代码编写上切实有效的建议以及代码设计都是非常有价值的。每日搜罗最具权威专业书籍,更多图书请关注“每日读本书”。
686 0
读《思考致富》
关于作者 拿破仑·希尔,现代成功学大师,励志书籍作家,曾任美国罗斯福总统首席顾问。他早年开始研究钢铁大王卡内基、发明家爱迪生、发明家贝尔等500名成功人士的伟大成就,他的成功秘诀的研究影响遍及全球数万人。
1217 0
|
数据安全/隐私保护
读《梦的解析》
 弗洛伊德认为,梦的核心本质是人内心某种愿望的达成。 西格蒙德·弗洛伊德,奥地利精神医师、著名心理学家、精神分析学派的创始人,在心理学界是泰山北斗级的人物。
1272 0
|
关系型数据库 Oracle Linux
[20180410]为什么2个逻辑读不一样.txt
[20180410]为什么2个逻辑读不一样.txt --//昨天做测试时,发现一个小问题,链接http://blog.itpub.net/267265/viewspace-2152693/ --//发现2个逻辑读不一样,做一些简单探究.
932 0