阁龙1427 发表于 2016-7-7 16:13:34

如何阅读代码

本帖最后由 阁龙1427 于 2016-11-29 09:17 编辑

工作时间不短了,看别人的代码着实是一件闹心的事情。今天和几个攻城狮讨论如何有效的阅读C语言代码,颇有心得。又看到很少讨论阅读代码的帖子。
故来抛砖引玉:

1-首先有效阅读代码背后的含义是理解模块的运行机制,理解了这一点之后就好了,因为我们将从另外角度来说。
是什么角度呢?那就是从数据结构的角度。代码都是对数据的操作,所以我们理清楚了有什么需要操作的数据结构,不用阅读完代码,仅仅从逻辑的角度你就知道他怎么运行了。

2-带着问题去阅读,有什么重要的数据结构,是怎么用的,用一个根问题开始,慢慢理解完数据结构的使用。尤其对于嵌入式软件工程师来说,这一点更为重要。比如,我们去看nand flash驱动,在数据结构里面有日志块,空块,free块。我们就知道这三个块之间肯定有着某种联系,根据自己的推测去阅读代码很快就会理解。

3-如果有前面的人维护或者能找到开发这个代码的人是最好的,有了自己的想法之后可以和这些人多多讨论,很多时候会有意想不到的收获(比如对代码的设计逻辑产生一个优化的策略,对于自己代码设计架构也会有一些意义,这也是阅读代码的优点之一【很累】)。

4-亲自操刀去验证一些想法是一个非常重要的锻炼途径,对比着代码阅读器(SI)调试工具+datasheet(specifcation)
希望能够成为一个好的帖子,大家多来讨论讨论,让更多鱼油看到,从一个不一样的角度理解程序。


分享两个比较好的帖子(感谢杨博士推荐):
http://blog.csdn.net/ilyfeng1314/article/details/7452326
http://www.cnblogs.com/ToDoToTry/archive/2009/06/21/1507760.html


边看代码边画有助于理解代码的流程图:

阁龙1427 发表于 2016-7-7 16:14:21

我会不定期更新这个帖子的

阁龙1427 发表于 2016-7-8 09:19:28

都来关注讨论一下呀

小甲鱼 发表于 2016-8-1 03:47:12

{:10_278:}阅读代码呀,看注释,看注释,看注释!!

阁龙1427 发表于 2016-8-1 12:05:28

小甲鱼 发表于 2016-8-1 03:47
阅读代码呀,看注释,看注释,看注释!!

代码更迭太多,注释没有及时更新就麻烦

qq554123053 发表于 2016-8-2 00:17:21

命令好难记

cosmosh73 发表于 2016-8-24 11:15:24

看看
页: [1]
查看完整版本: 如何阅读代码