转自: http://zz563143188.iteye.com/blog/1844388

本文的这些最佳实践、开发准则都是伟大的程序员的经验总结。Tim Oxley从互联网中搜集了这些最佳实践,并放在了Github上,以供他人查看和补充。希望这些最佳实践能够为你的开发工作带来一些帮助。

本文的这些最佳编程实践、开发准则都是伟大的程序员的经验总结。Tim Oxley从互联网中搜集了这些最佳实践,并放在了Github上,以供他人查看和补充。希望这些最佳实践能够为你的开发工作带来一些帮助。

1.  不要构建大型应用

构建大型应用的秘诀就是“不要构建大型应用”,也就是把你的应用拆分成若干小应用,然后将这些可测试的小应用组装到一起。——Justin Meyer,JavaScript MVC作者

2.  注重项目质量

当我听到“匆忙做出了能够运行的代码”,我也许不会去使用这些应用程序,因为它们会逐渐丧失可迭代的能力。——Avdi Grimm

3.  不写代码

“Don’t write code”是每一个开发人员都需要学习的最重要的一条准则。目前存在大量重复的、蹩脚的代码(跨项目),在很多情况下,开发者甚至不去仔细看看周围有什么,他们只是一味地编写代码。

4.  将减少产品中代码量作为目标

我讨厌代码,我希望在我们的产品中代码尽可能少。——Jack Diederich

5.  保持最少依赖

经典格言“不要重新发明轮子”并不适用于火车头处的轮子(指项目的核心部分)。

6.  停止编写类

“这不应该是一个类”,尤其是在类有两个方法,且其中一个是构造函数时。任何时候你看到这种情况时,你也许只应该写一个函数。——Jack Diederich

7.  忘掉新功能,将同样的东西做得更好

开发者容易忽视而用户通常比较关心的东西是——应用程序中最常用功能的性能和可用性。——Tim Anderson

8.  重新发明轮子

发明自己的轮子,可以让你更深刻地理解轮子如何工作,以及如何才能做得更好。

9.  做容易的事情,而不是难的

  • 简单比复杂好
  • 复杂(Complex)比超复杂(complicated)好
  • 顺序比嵌入好
  • 可读性应当被重视
  • 如果你的代码实现难以解释,这不是一个好的实现

——The Zen of Python(Python禅宗)

10.  重写>重构

如果你正在更改一个类或方法超过25%的部分,你可以考虑重写,你的代码将会更加整洁。

11.  重构>重写

重写一个项目的常见借口:

  • 代码很烂
  • 我们现在更聪明了
  • 我们选错平台/语言了

为什么重写(几乎)不是一个好主意:

  • 它总是需要比你预期更长的时间
  • 市场在不断变化
  • 现有客户会变得沮丧
  • 重构也可以清理代码
  • 你无法控制重写的代码,最后会变成它在控制你

12.  你不知道项目将如何增长

从一开始你就要承认,你不知道项目会如何增长。一旦你承认这一切,你就会开始防御性地设计系统……你应该花大部分的时间来考虑接口,而不是实现。——Nicholas Zakas,《高性能JavaScript网站》作者

13.  避免代码味道(指代码中存在潜在问题)

14.  写单元测试

每个程序员都知道他们应该为自己的代码编写测试,但很少有人会这样做。问其“为什么不呢?”通常会回应“我太忙了。”这很快就会变成了一个恶性循环——你感到压力越大(越忙),你写的测试就会越少,你的代码也会变得不太稳定,你的生产力会越来越低。这样一来,你的压力就更大了(工作更忙了)。正是由于这样的恶性循环,导致程序员的编码热情降低。我们发现,有时一个简单的测试框架,就可以让工作有很大的不同。

(没有单元测试)你不是在重构,你只是正在改变一堆狗屎。——Hamlet D'Arcy

15.  测试驱动开发&控制反转(Inversion of Control)

即使你的代码不需要测试,你也应该编写可测试的代码。IoC(控制反转)可以帮你这样做。尝试在测试时注入对测试友好的依赖或模拟实例,并隔离受测试单元。

16.  避免将对象创建与应用程序逻辑混合在一起

17.  避免创建技术债务

尽管不成熟的代码可以正常工作,客户也完全可以接受,但是最后出现的技术债务将会使你疲惫不堪,整个工作组也有可能会被这些技术债务困在原地。

18.  过早优化是罪恶之源

一些程序员会浪费大量的时间去思考或担心程序中非关键部分的运行速度,而他们的这些尝试有可能会对最终的调试和维护产生负面影响。我们应该忘掉小的效率,在97%的时间内告诫自己“过早优化是罪恶之源”,但是,也一定不能在关键的3%上错过优化机会。

19.  计划,计划,计划

首次就做正确的事情比稍后重做的代价要小得多,发现解决问题越早,代价就越小。

夫未战而庙算胜者,得算多也;未战而庙算不胜者,得算少也。多算胜少算,而况于无算乎!吾以此观之,胜负见矣。——孙子兵法

计划是无用的,规划是无价的。——温斯顿•丘吉尔

20.  一个不断学习的编程团队

即使一个团队中的程序员平庸、缺乏经验,但如果他们都为团队利益而编写代码,就有可能会成为一支伟大的团队。这一切都要看该团队是否能够意识到他们的工作只是写代码或将写代码和学习作为首要目标。——Reginald Braithwaite

21.  不断评估、完善

软件设计是一个迭代的过程,在一开始不可能什么都考虑到,需要在之后的过程中通过经验来不断完善。而且通常情况下,很少有软件项目能够完全按照预期来完成,随着项目的进展,对于项目的预期也会下降。

22.  什么是架构

你的项目架构反映了什么?是医疗保健系统、会计系统、库存管理系统,还是rails、spring/hibernate、ASP?

软件产品的架构应该让所有人都很容易了解产品所要达到的目的,并且系统的架构应该反映系统的用例而不是它使用的框架。架构不是(或不应该是)关于框架的内容。架构不应该由框架支持。框架是我们要使用的工具,而不是要符合的架构。如果你的架构基于框架,那么它就无法基于你的用例。——Uncle Bob Martin,《尖叫的架构(Screaming Architecture)》作者

23.  X-Windows系统设计原则

  • 不用增加新的功能,除非没有它就无法完成一个真正完整的应用程序
  • 决定一个系统不是什么和决定它是什么同样重要。你无法满足世界上所有人的需求,好的做法是,使系统可以以向上兼容的方式扩展,以便能够满足额外需求。
  • 比从一个例子中归纳,更坏的是,没有可归纳的例子。
  • 如果你不能完全了解一个问题,那么最好别提供任何解决之道。
  • 如果预期要用90%的努力去完成10%的工作,那么应该用更简单的办法解决。
  • 尽量避免复杂性
  • 提供机制而不是策略,实践中把用户方面策略放在用户手里。

24.  Unix设计原则

  • 模块化准则:编写简单的模块用清晰的接口把它们连接起来。
  • 清晰性准则:清晰性优先于巧妙。
  • 组合准则:设计可以和其他程序连接的程序。
  • 分离准则:把政策和机制相分离;把接口和引擎相分离。
  • 简单性准则:设计追求简单性,只在绝对必须时加入复杂性。
  • 节俭准则:只在通过原型澄清后才编写大的程序。
  • 透明性准则:设计的可见性使检查和除错更容易。
  • 健壮性准则:健壮性是透明性和简单性的孩子。
  • 表示准则:将知识包入数据,程序逻辑可以是笨拙和健壮的。
  • 最小惊喜准则:在界面设计中,总是遵循最小惊喜准则(总是做令人惊喜的事情)。
  • 沉默准则:如果程序没有重要的输出,它就应该保持沉默。
  • 修复准则:如果你必须出错,尽可能响亮和快速的出错。
  • 经济性准则:如果和机器时间比较,程序员的时间是昂贵的。
  • 生成准则:避免手工编程,如果可能,编写编写程序的程序。
  • 优化准则:在打磨前建立原型,在你优化前先使他工作。
  • 多样性准则:怀疑一切声称“只能如此”的说法。
  • 扩展性准则:为未来设计,因为它往往来的比你想得快。

——Eric S. Raymond,《Unix编程艺术》作者

转载于:https://www.cnblogs.com/jym-sunshine/p/5420324.html

软件开发实践的24条军规相关推荐

  1. 解密谷歌机器学习工程最佳实践——机器学习43条军规 翻译 2017年09月19日 10:54:58 98310 本文是对Rules of Machine Learning: Best Practice

    解密谷歌机器学习工程最佳实践--机器学习43条军规 翻译 2017年09月19日 10:54:58 983 1 0 本文是对Rules of Machine Learning: Best Practi ...

  2. 敏捷软件开发实践——估算与计划02

    目录 一.使用故事点估算大小 1.故事点是相对的 2.速度 3.小结 二.使用理想人天进行估算 1.理想时间和软件开发 2.以理想人天作为对大小的度量 3.给出一个而不是多个估算值 4.小结 三.估算 ...

  3. 敏捷软件开发实践——估算与计划(01)

    目录 一.计划的目的 1.为什么要进行估算和计划 2.优秀的计划是什么 3.敏捷计划是什么 4.小结 二.计划失败的原因 1.基于活动而不是基于特性进行计划 1.1.活动不会提前完成 1.2.延误沿着 ...

  4. 软件开发计划_敏捷软件开发实践:估算与计划读书笔记113第11章 确定渴望度优先级...

    <敏捷软件开发实践:估算与计划>第11章 确定渴望度优先级,重点和要点的思维导图及文字内容. 第11章 确定渴望度优先级 If you have a choice of two thing ...

  5. 校级选修课《软件开发实践》教学大纲(200807修订)

    软件开发实践 Software Developement Practice 课程代码:                        学    分:2.5 总学时: 40 学时             ...

  6. 软件开发计划_敏捷软件开发实践:估算与计划读书笔记123第21章 关于计划的沟通...

    <敏捷软件开发实践:估算与计划>第21章 关于计划的沟通,重点和要点的思维导图及文字内容. 第21章 关于计划的沟通 The more elaborate our means of com ...

  7. 手机网络应用客户端软件开发实践简介

    网络应用与客户端软件 说到移动网络应用,前几年大家首先想到的就是WAP应用.最近随着市场上手机的可编程能力越来越强,手机软件开发平台和产业链的逐渐成熟,手机上的网络应用软件逐渐多了起来,如移动QQ.P ...

  8. 手机网络应用客户端软件开发实践简介(摘自www.j2medev.com)

    网络应用与客户端软件 说到移动网络应用,前几年大家首先想到的就是WAP应用.最近随着市场上手机的可编程能力越来越强,手机软件开发平台和产业链的逐渐成熟,手机上的网络应用软件逐渐多了起来,如移动QQ.P ...

  9. Android图片海报制作软件开发实践

    Android图片海报制作软件开发实践 项目地址:https://github.com/coolstar1204/MakePoster 本博客分以下几个文章,从头记录我学习Material Desig ...

最新文章

  1. cad表示计算机辅助,CAD计算机辅助设计之快捷键篇~( ̄▽ ̄)
  2. js 获取vue组件html_vue.js中怎么引入组件?
  3. 雷军的手机屏保亮了,网友哭笑不得:我还以为是董明珠呢!
  4. html5css3背景下雪,HTML5 CSS3下雪奥运五环背景动画特效
  5. 个人计算机网刻系统,诚龙网维全自动pxe网刻工具_win7网刻工具_网刻win7系统工具...
  6. 基于matlab使用Windrose函数绘制风矢量分布图(风玫瑰图)
  7. 傅立叶变换描述子 matlab,[傅里叶变换matlab]傅里叶变换的Matlab代码与注释
  8. MySQL5.5安装步骤
  9. 计算机在职研是不是双证,计算机双证在职研究生好考吗?
  10. firefox插件grease_monkey
  11. 如何修改已提交commit信息
  12. 怎样在M1或Intel Mac上重置NVRAM
  13. proguard 配置简介
  14. 猿哥翻译的以太坊黄皮书
  15. Qt crc16校验位计算
  16. 18-TFRecord 数据格式化存储工具(CDBmax 数据国度)
  17. CCRC信息安全服务资质--应急处理
  18. YOLO系列 --- YOLOV7算法(四):YOLO V7算法网络结构解析
  19. 容性负载、阻性负载、感性负载、功率型负载的区别
  20. 智安网络|弹性网络与网络安全:保卫数字世界的关键联结

热门文章

  1. pjk static tp.php,在测试服上偶然出现 Error: Loading chunk 5 failed.
  2. 【PAT乙】1005 继续(3n+1)猜想 (25分)
  3. JAVA面向对象OOP多态→抽象类abstract、接口interface实现implement、final不变修饰符、样例代码
  4. JavaScript的预解析(1)
  5. 通信中的ATM cell:ATM信源结构
  6. p70_域名解析系统DNS
  7. 如何使用Burp Suite代理
  8. bzoj 1296: [SCOI2009]粉刷匠(DP+DP)
  9. bzoj 4514: [Sdoi2016]数字配对(二分图+费用最大流)
  10. bzoj 1058: [ZJOI2007]报表统计(set+multiset)