程序员如何做到「编程速度又快,Bug 数量又少」?

最近看到一个Quora中的回答,答到心坎上。译文引用自伯乐在线:

  三个程序员被要求穿过一片田地,到达另一侧的房子。

  菜鸟程序员目测了一下之间很短的距离,说:“不远!我只要十分钟。”

  资深程序员看了一眼田地,想了一会,说:“我应该能在一天内过去。”菜鸟程序员很惊讶。

  大神程序员看了一眼田地,说:“看起来要十分钟,但我觉得十五分钟应该够了。” 资深程序员冷笑了一声。

  菜鸟程序员出发了,但只过了一会,地雷爆炸了,炸出了巨大的洞。这下他必须偏移预定的路线,原路返回,反复尝试穿过田地。最后他花了两天到达目的地,到的时候颤颤发抖,还受了伤。

  资深程序员一出发就匍匐前进,仔细地拍打地面,寻找地雷,只有在安全的时候才前进。他在一天的时间内小心谨慎地缓慢爬过了这片地,只触发了几个地雷。

  大神程序员出发之后径直穿过了田地,十分果断。他只用了十分钟就到了另一边。

  “你是怎么做到的?”另外两个人问道,“那些地雷怎么没有伤到你?”

  “很简单,”他回答道,“我最初就没有埋地雷。”

  地雷从何而来?

  与大神一起工作的时候就是这种感觉,也是我的第一印象「代码整洁而且没有地雷」。可是反过来想,为什么有的人就是习惯于埋雷呢?难道看不到后果吗? 再深一层来讲,没人愿意给自己埋地雷,主要还是没有对习惯引起重视。培养起好的编程习惯是非常重要的。编程中的坏习惯,是很多程序员上升的天花板,十年原 地踏步的原因。想要写出好代码,一定要常常问自己「我还能做的更好吗?」(好吧,这是算法课的口号)。只有想不断提升的人,才会注意去扣各种各样的细节, 使得自己做得比前一次好。下面总结一下,常见的「地雷」有哪些:

  没有提前构建

  没有规划完整系统的生命周期,内存泄露到处都是。

  系统没有设计好,存在不少重复功能的类。

  系统的行为没有定义好,接口设计不完整,写了创建不写删除。

  没有重视代码的可读性

  代码没有经过提炼,到处都是重复代码,改一个功能常常要改很多处代码。

  缺少抽象,将具体实现暴露得到处都是。比如一个状态机在外部设置它的状态切换。

  代码没有紧贴语义。

  没有重视开发效率

  到处都是繁杂重复的配置项,通过约定可以省去很多配置。

  很多中间代码,比如解析xml、解析协议等等的工作,通过元编程可以将这些中间工作自动化。

  没有重视数据

  数据没有处理好,敏感数据要保护好,比如角色的属性,到处都是直接赋值的话,很容易出错,要把直接改变限制在少数的某几个函数里。

  某些系统知道得太多,比如数据层就不应该知道显示层的东西,显示和数据掺杂在一起。

  数据依赖于代码,比如写在C++的模板里面,没有为数据设计序列化文件。

  更深层的原因

  “我不是什么伟大的程序员,我只是一个有着很多好习惯的程序员”—-Kent Beck

  在《程序员修炼之道》里,第一条就是「关心你的技艺」。如果你不在乎能否漂亮地开发出软件,你又如何要耗费生命去开发软件呢?

原文发布于微信公众号 - php(phpdaily)

原文发表时间:2015-12-03

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏程序员互动联盟

【答疑释惑第十四讲】如何学习数据结构?

疑惑一 为什么学习编程前,先要掌握计算机组成原理? 很多的学习编程的小伙伴,特别是上来就学习java的小伙伴,很多对底层语言的实现存在一种莫名的畏惧感,老是觉得...

2956
来自专栏CDA数据分析师

扫盲!SPSS,SAS,Stata,R有何区别,你选哪个?

对于各式各样的数据统计分析软件,你了解多少呢?经过潜心搜集,整理,我总结了一些软件的大体介绍及区别,欢迎大家指正和补充。 这里先略过Excel和Eviews这...

2336
来自专栏阮一峰的网络日志

关于Slashdot

slashdot.org创办于1997年,是一个著名的科技新闻网站。它的稿件都是由读者投稿,编辑审核后发表。但是,真正有趣的部分却是它的读者留言。

511
来自专栏C语言及其他语言

C语言网(dotcpp.com)Get新玩法

最近,不知道大家有没有注意咱们C语言网的变化(www.dotcpp.com) 最近一周,又有新功能新资源发布,下面给大家汇报: 评测结果有了详细的提示信息,除了...

3439
来自专栏racaljk

当我们谈论计算机科学

下午偶有所悟,特作此文防止青年痴呆。 这学期的学习算是走了一半计算机科学概论。广度的学习通常会被指责为广而不精,但对我而言这是毫无意义的,因为 ...

804
来自专栏Albert陈凯

如何高效地学习编程语言

这是Clojure好书《Clojure for the Brave and True》作者 Daniel Higginbotham 写于2017年4月16日的博...

3396
来自专栏钱曙光的专栏

一周极客热文:8张图理解Java

图:equals()方法、hashCode()方法的区别 HashCode被设计用来提高性能。equals()方法与hashCode()方法的区别在于: 如果两...

1737
来自专栏编舟记

如何高效地学习编程语言

学习编程语言是一种技巧:做好了,你会感受到掌握新事物之后的快感(dopamine:多巴胺);做不好,就会接二连三的沮丧,甚至放弃。下面这些学习编程语言的最佳技巧...

754
来自专栏一名叫大蕉的程序员

手把脚教你实现第一个在线预测系统No.21

本来呢,最近看了人类简史,想写一篇偏见相关的,思路还没整理好不好放出来,先写个技术的吧。最近真是忙成狗,搬职场,找房子租,参加各种各样的会议,还有开发任务,做屁...

18310
来自专栏理论坞

产品动效设计全方位科普手册,超级全面的分析!

本文主要讲述了为什么做动效,好的动效设计的标准是什么,如何做动效设计,以及如何使自己设计的动效完美落地。

411

扫码关注云+社区