StackOverflow 创始人关于如何高效编程的清单

转载 2017年08月04日 17:14:55

转自:https://mp.weixin.qq.com/s?__biz=MzIwMzg1ODcwMw==&mid=2247486219&idx=1&sn=9db802a5cb5b2dd3fa8058f6f6e6cfaa&source=41#wechat_redirect


策划|Jeff Atwood

编辑|薛命灯

这是 StackOverflow 联合创始人 Jeff Atwood 注释的十戒。程序员普遍有很强的自尊心,都应该看看本文,打印下来时刻提醒自己。

“无我编程”发生在开发阶段,表现为技术团队经常通过同级评审的方式来发现软件中的缺陷。目的是让所有人(包括作者)都参与寻找缺陷,而不是证明软件产品里没有缺陷。人们会交换各自手上的代码,相互进行评审,并且大家都有这样的共识:代码的原始作者会犯错误,而作为评审者,他们会找出这些错误。最后的结果是,每个人都从自己的错误以及别人的错误里有所长进。这就是“无我编程”的由来。

无我编程的十条戒律,最早出现在 Gerald Weinberg 于 1971 年出版的经典著作《程序开发心理学》里。Stack Overflow 网站的联合创始人 Jeff Atwood 在博客上再次列出了这十条戒律。要知道,在这本著作出版的时候,Jeff 才一岁。虽然已经过去了几十年,但这些原则并没有被时间侵蚀,仍然值得每一位程序员拜读。

  1. 接受自己会犯错的事实。关键是要在错误进入到生产环境之前把它们找出来。所幸的是,除了小部分在喷气推进实验室里开发火箭制导系统的程序员,大部分错误都不会造成致命的后果。所以,我们一定能够而且也应该要学会嫣然一笑,然后继续。

  2. 不要使用代码来针对个人。要记住,代码评审的目的是为了找出问题,而且总归会找到问题。如果真的找到了问题,请不要把它作为针对个人的借口。

  3. 不管你知道多少“秘籍”,总有人比你知道得更多。如果你开口,他们就会教你更多的东西。在你认为没有必要的时候,学会接受他人的建议。

  4. 不要不经讨论地重写代码。“修复代码”与“重写代码”是有明显的区别的。了解这些区别,并在代码评审的框架之内进行程式化的变更,而不是单独作战。

  5. 尊重比你懂得少的人,并对他们抱以耐心。与技术人员打交道的非技术人员认为技术人员要么是妄自尊大的讨厌鬼,要么是爱撂挑子的倔驴。所以,我们不要用我们的愤怒和不耐烦去加深他们对我们的这种印象。

  6. 这个世界唯一不变的就是变化。敞开胸怀,面带微笑地去拥抱变化。把每一个需求变更、平台变更或工具变更都看成是一个新的挑战,而不是令人厌恶的麻烦。

  7. 真正的权威来自于知识,而不是职位。知识造就了权威,而权威会迎来尊重。如果你想要在一个无我的环境里得到尊重,那么充实你的知识吧。

  8. 坚定你的立场,优雅地接受挑战。要知道,你的想法有时候会遭到反对。你可以证明自己是对的,但不要试图报复,不要总是叫嚷着“我早就说过”,不要被否定的想法看成是一个牺牲品或者某种战斗口号。

  9. 不要成为“小黑屋里的人”。不要躲在小黑屋里写代码,就算偶尔露个面,也只是为了买一杯可乐。躲在小黑屋里只会让你与其他人失去联系,淡出他们的视野,失去控制。在一个开放的协作环境里,你会找不到自己的位置。

  10. 批评代码,而不是人。对人好一点,而不是代码。让你所有的评审为代码带来积极的改进,把你的评审与局部标准、程序规范和更好的性能结合在一起。


StackOverflow 创始人推荐图书

  • 2016年06月13日 23:19
  • 1.74MB
  • 下载

Stack Overflow上提到的最多书籍的排行

闲了也是闲,偶尔逛逛Hacker News,自己的英语很水,逛街呢也希望能多多提高下自己,于是乎,见到一些文章,mark的同时,也同样enjoy it。原文地址:http://www.dev-book...
  • huanglong8
  • huanglong8
  • 2017-02-09 11:54:06
  • 582

stackoverflow重要性

作为一名程序员,如果没有听过 Stackoverflow,那么你最好去面壁思过一下。程序员最需要阅读的一本编程书籍(其实编程书留下这本就够了!):      (主页君强势插入,上图是一张恶搞图,之...
  • qq_27231343
  • qq_27231343
  • 2016-08-25 22:40:15
  • 824

如何解决stackoverflow访问速度慢的问题

最近查找技术问题需要用到stackoverflow,但是发现访问速度非常慢,经常还超时无法访问。经过查阅多种资料后,发现以下的替代方案能够完美解决这个问题: stackoverflow网站访问慢...
  • gengsuning
  • gengsuning
  • 2017-10-29 21:41:23
  • 451

高质量C++编程指南

  • 2009年07月16日 09:30
  • 328KB
  • 下载

Stackoverflow使用

Stackoverflow说明书箱:essential-copying-and-pasting-from-stack-overflow 原谅与翻译见:原文与翻译 提问的智慧 当你拋出一个技术...
  • jun55xiu
  • jun55xiu
  • 2017-05-09 16:45:15
  • 566

第一次在stackoverflow上提问,亮瞎了。。

下午看oc代码,看到这么一句 array_multisort($sort_order, SORT_ASC, $method_data); 这个是对多个数组进行排序的,倒是没什么好说。然后我...
  • u010703523
  • u010703523
  • 2015-06-29 20:38:59
  • 3182

MySQL高效编程_完整版

  • 2017年12月14日 13:39
  • 37.57MB
  • 下载

如何在stack overflow提问

写这篇博客的原因主要是在stackoverflow上面提了一个不符合规范的问题,后来找到了stackoverflow的帮助,我翻译总结了一下,如何提一个高质量的问题. 如何在stack overfl...
  • micaixiaoduanku
  • micaixiaoduanku
  • 2016-09-22 16:23:59
  • 655

我也来列一列我的读书清单

1.c语言程序设计 2.面向对象程序设计(c++描述) 3.数据结构 4.算法设计与分析 5.操作系统 6.计算机网络 7.数据库系统 8.编译原理 9.编程之美 10.剑指offer 11.java...
  • huaweitman
  • huaweitman
  • 2016-11-06 22:49:18
  • 363
收藏助手
不良信息举报
您举报文章:StackOverflow 创始人关于如何高效编程的清单
举报原因:
原因补充:

(最多只允许输入30个字)