《代码大全2》读书笔记 week 7

       博主终于继续更《代码大全2》了 (*´・ω・`)⊃,课上老师一再强调读书笔记要写出自己的心得不能简单摘抄,所以我现在基本上只会写一下自己在阅读过程中印象深刻或者有发散思考的地方,字数可能会明显减少。其实之前按原文大段摘抄是考虑到也许真的有一些没办法看到原著的读者......

      本周我阅读了第九章“伪代码编程过程”和第十章“使用变量的一般事项”。第九章主要介绍了伪代码编程过程(Pseudocode Programming Process, PPP)如何减少设计和编写文档的工作量,以及提高这两项工作的质量,而第十章从变量的定义、初始化、引用、作用域、生命周期各个方面阐述了使用变量的一般注意事项。

      我自己再正式编程之前习惯在纸上写下总体思路 ,对于一些起到关键作用或者算法比较复杂的子程序或类,写下构思的过程中不知不觉就会使用程序语言,待停笔,纸上已经是满满一页代码。一方面这种做法完美跳过了伪代码的步骤,另外,将纸上的代码转移到电脑上可能引入新的错误,而且很多情况下浪费了时间。书中作者所推崇的伪代码编程过程,是用类似自然语言(比如中文、英语)的语句来精确描述特定的操作,而且要避免使用目标编程语言中的语法元素。根据我的了解,我身边的很多同学也并不喜欢撰写伪码,甚至以能迅速上手编程为豪。阅读了这一章后我确实意识到了编写伪码的诸多好处,虽然在实践过程中无法做到书中作者所要求的所有步骤,但从中吸取经验是必要的。根据书中内容,我总结了编写伪码的一些优点:

      1.从本意的层面——比代码更高的层次、更自然的层次上去设计类或子程序,可以让开发者更迅速并相对准确地表述出自己的思路
      2.对各种编程语言通用,具有良好的可移植性
      3.让高层设计的错误更明显,检查细节上的设计时不用读源代码,减少了评审工作的复杂度
      4.伪代码的许多部分可以作为注释和文档中的语句
      5.减少做出变更的代价(对于复杂的的工程,一句伪代码的改变可能涉及到源代码中的许多地方)
      6.可以在伪代码中实验各种方案、想法,毕竟真正开始编程后就会对自己的代码产生情感,推倒从来是一个巨大的心理挑战

      第十章所提到的诸多变量使用上的规则,我们从刚开始学编程就已经有所耳闻,实践过程中也在走过大大小小的坎后对这些规则有了更深刻的体会。书中作者将这些使用规则提升到理论层面,为我们详细地论证了它们的重要性。以下只列举若干我印象比较深刻的知识要点:     

      1.在靠近变量第一次使用的位置初始化它,如果编程语言支持的话,在靠近变量第一次使用的位置定义和声明的它。

      2.保持变量需要重新初始化的假设,尤其对于累加器和计数器而言。

      3.就近原则,把相关的操作放在一起,使变量引用局部化,减小平均跨度, 提高程序的可读性,也易于查错。

      4.跨度指示对一个变量引用的集中程度,存活时间指示变量从被定义到最后一次被引用历经的语句数量。缩短变量存活时间可以增强代码的可读性,减小修改语句过程中变量值被错误修改的可能性,需要把一个大程序分成小程序时,这种做法也很有价值。

      5.绑定时间指变量和它的值绑定在一起的时间,一般有五个层次:编码时->编译时->加载时对象实例化时->即时,复杂度依次升高,灵活性也依次增大。灵活性和复杂度常常会发生冲突,好的程序员善于从中找到平衡,在满足灵活性要求的同时又不引入额外的复杂度。

      除此之外,这两次编程作业中我吸取到的经验教训恰好验证了这两章中的一些建议。比如,设计子程序或类的同时要考虑如何测试,这对迭代式开发大有裨益;在为如何提高每个子程序的效率苦苦思索前,优先考虑高层设计的优化,选用更合适的算法或数据结构。在编程作业中,我在优化阶段的一些改动实际上是违反编程规范的,但事实上一些看似会拖慢运行速度的规范限制并不是问题症结所在,符合规范的代码实际上是能提高效率的,当代码效率低下时,一般不是由于代码规范的约束,而往往是高层设计(比如算法、数据结构、乃至整个顶层设计)的缺陷。

 

posted @ 2018-04-18 21:26  Viarow  阅读(181)  评论(1编辑  收藏  举报