代码改变世界

第十次读书笔记

2018-05-31 20:08  ccj1998  阅读(285)  评论(0编辑  收藏  举报

       前几周读了Jon Bentley的著作《编程珠玑》部分章节,这本书对于我这种虽然上了一学期软工但是还是新手的人很友好,大多是讲一些遇到问题是的解决思维与平时编程时的思路问题,对我很有帮助。

      大多时候,我们十分注意解决问题所用的算法,而忽视问题本身的重要性。拿到问题的第一步,应该研究问题的每一个细节,细节的偏差会导致解决问题时方法的重大不同。如果我们研究问题本身的时间花的太少,很可能会走很多弯路,事倍功半。

      令我感兴趣的是文中关于代码调优法则的讨论。里面设计到很多法则。首先是空间换时间法则。空间换时间在很多地方都见得到。如哈希表开得越大一般效率就越高。在今天尤为适用更追求速度提升时代,空间换时间的思想尤为适用。循环法则也是很重要的一条。常见的应用有:将代码移出循环、循环展开、删除赋值、消除无条件分支、循环合并等。另外我们应该减少过程调用,因为这会带来大量开销。我们还可以减少不必要的存储器调用,如引入临时变量。在每次迭代中执行更多的数据操作来减小循环开销。还有,使用指针而不是数组进行引用也能改进程序的性能。但是书中也指出,优化的性能是有限的,并且我们需要在程序的简单性和运行速度之间进行权衡折中,因为优化往往伴随着抽象性的降低。