程序员提升效率的十八大法则

经过多年的积累,我发现,下面这些基本的指导法则,可以帮助我成为一个更加高效的程序员

程序设计法则,与设计和工程的原理密切相关。下面这些编程法则帮助我让我获益匪浅,所以我想分享给大家,希望也能帮助大家更高效,生产出的代码更容易维护,并且bug和缺陷更少。

DRY原则

不要重复(Don’t repeat yourself)——程序设计中一个最根本的原则就是要避免重复。许多编程结构(比如循环、函数、类等)的存在就是为了避免重复。一旦重复(例如,一个长表达式,一系列语句,相同的概念)的话,就会创建一个新的抽象。

抽象原则

“每个在程序中有意义的功能片段应该只在源代码的一处地方实现。”

KISS(Keep it simple, stupid!)原则

简单性(避免复杂性)应该永远当作是一个重要的目标。写简单的代码,不但花费的时间少,错误少,而且修改起来也容易。

避免创建YAGNI(You aren’t going to need it)原则

只有当你需要的时候才去添加额外的功能,不需要就不要画蛇添足。

方法要最简单,效果要一样好

在编程时,我们需要问问自己:“有没有最简单的完成任务的途径?”这有助于我们保持一直行走在简约设计的道路上。

不要让我思考

这实际上是由Steve Krug写的一本书的书名。关键要点是,代码应该尽可能地易于阅读和理解。如果阅读人需要大量的思考才能理解代码,那么或许这代码还需要被简化。

开/闭原则

软件实体(类,模块,函数等)在扩展时应该开放,在修改时应该关闭。换句话说,你写的类大家可以扩展,但不能修改。

为维护者写代码

值得写的代码要保证将来一定值得维护。未来的你由于经历的代码太多,也许再回过头来看这些代码的时候,也和其他人一样,已经成为了一个完全的陌生人。请记住,“写代码的时候,就假设将来要维护的人是个知道你住在哪里的暴力型精神病患者吧。”

最小惊讶原则

最小惊讶原则通常引用于用户界面方面,但这一原则也适用于编写代码。代码应该尽可能地不要让阅读者惊讶。遵守标准约定,注释说什么代码就做什么,命名是什么意思代码就是什么意思,尽可能地避免惊讶导致的潜在的负面影响。

单一职责原则

代码(如类或函数)的组成部分执行的应该是一个单一的明确的任务。

最小化耦合原则

代码的任何部分(代码块,函数,类等)都应该尽量减少对其他代码的依赖。这可以通过尽量不要使用共享变量来实现。“低耦合常常是计算机系统构造良好和设计良好的标志,并且当和高内聚力相结合的话,还可以大大支持高可读性和可维护性的整体目标。”

最大化内聚原则

具有相似功能的代码应该放在同一个组件内。

隐藏实现细节原则

隐藏实现细节,允许在改变代码组件的实现的同时,最低限度地减少对使用该组件的其他模块的影响。

得墨忒耳定律

代码组件应该只和它们的直接关系(如,继承的类,包含的对象,通过参数传递的对象等)沟通。

避免过早优化原则

除非代码开始工作,否则甚至就不要有优化的念头。只有当你必须要优化的时候,才能借助实战数据的帮助。 “我们一定要有大局观:过早的优化是万恶之源”——Donald Knuth。

重用代码才是好代码

这和任何其他法则一样之精辟。重用代码可以提高代码的可靠性,并减少开发时间。

关注点分离原则

不同的功能区域应该由明显的重叠最小的代码模块进行管理。

拥抱变化原则

这是Kent
Beck写的一本书的副标题,也被认为是极端编程和通用敏捷方法的原则。许多其他原则都基于这个理念:你应该期待和欢迎变化。事实上,很多古老的软件工程
法则,例如最小化耦合原则,就是和让代码变得更容易改变是直接相关的。无论你是不是一个极端编程的实践者,这种写代码的方法真的很有意义。

有什么想法吗?欢迎参与到我们热烈的讨论中来!

作者:小峰

来源:51CTO

时间: 2025-01-27 23:47:15

程序员提升效率的十八大法则的相关文章

面向程序员的数据库访问性能优化法则

面向程序员的数据库访问性能优化法则     http://blog.csdn.net/yzsind/archive/2010/12/06/6059209.aspx

《程序员之禅》一一第10章 程序员之禅的10条法则

第10章 程序员之禅的10条法则 程序员之禅在一个飘雨的清晨,我坐在书桌前,思考如何进行高效率工作的问题.在成为自由职业者之前,我一度拼命工作而结果却令人闷郁.自2006年起,我开始参禅.过了许久,我终于明白,千百年前的禅师就已知道今天的程序员该如何工作.从那时起--尽管我并不喜欢"如何成为一名更好的程序员"之类的帖子,我便希望能够总结一下个人参禅心得.它可以让我保持清醒.如果你对这篇文章有什么看法,欢迎随评.

程序员之路:十年磨一剑

转载者注:本文为经典的关于学习编程的文章,铭此以自勉. 英文原文:Teach Yourself Programming in Ten Years (By Peter Norvig)         你们着什么急?        随意步入一家书店,满目都是<7天搞定 Java 编程>这种速成书目,同样的书籍还包括 Visual Basic.Window 系统.Internet 互联网等等,它们都承诺在几天,甚至几小时之内就让你能够学会相关技术.我在亚马逊网站上做了如下的条件检索:        

.NET程序员提高效率的70多个开发工具

工欲善其事,必先利其器,没有好的工具,怎么能高效的开发出高质量的代码呢?本文为各ASP.NET 开发者介绍一些高效实用的工具,涉及SQL 管理,VS插件,内存管理,诊断工具等,涉及开发过程的各个环节,让开发效率翻倍. Visual Studio Visual Studio Productivity Power tool: VS 专业版的效率工具. Web Essentials: 提高开发效率,能够有效的帮助开发人员编写CSS, JavaScript, HTML 等代码. MSVSMON: 远程D

程序员必须克服的十大编程禁忌

程序员在编程的时候难免会犯错误,但如果不从错误中吸取教训,那么习惯成自然,你会经常犯错的.从错误中不断的学习,锻炼好的行为习惯有助于事业上的稳定. 程序员在编程的时候难免会犯错误,但如果不从错误中吸取教训,那么习惯成自然,你会经常犯错的.从错误中不断的学习,锻炼好的行为习惯有助于事业上的稳定.这就是我们如何将小麦从糟糠中区别出来以及如何避免编程禁忌的绝佳经验.此外,最重要的就是可以为客户带来更好的用户体验. 1. 不提升非技术技能 我们认为非技术技能是项目成功的主要因素.这些非技术技能也可以称之

程序员,效率和质量你选谁?

本文作者系程序猿Daniel F Pupius,这是一篇他发表在Medium上的博文,讲述自己怎么在实际写代码的过程中,发现在效率和质量间做出抉择其实是个伪命题. 程序开发项目进行过程中,通常会冒出这样的困惑:应该选择效率,还是选择质量?很多程序猿都会有偷懒的思维,觉得把一些摸不清头绪.不知道怎么写的代码片段去掉,可以节省很多时间,更早完成项目计划. 其实过去几年中,我也是这么想的,但最近我开始意识到,这个问题的纠结之处不在于选择困难,而在于问题本身是个伪命题. 什么是"质量"呢?一般

第一个十年,我从教师转行为web程序员,下一个十年呢?

本来这篇水文没打算放到博客园上来的,今天想了想,也算是跟技术有一点沾边,还是从QQ空间转过来凑数吧 原文在QQ空间上的地址 : http://user.qzone.qq.com/278919507/blog/1282230041   2000年毕业走入社会,至今正好十年了,晚上看见某QQ好友的签名:十年!于是突然觉得应该把我的这十年记个流水帐,以便日后能记起这十年是如何度过的. 2000年8月:    因为一直不满父母/亲戚们强迫我读师范,一气之下,毕业时简历投给出了一个离家很远的学校:浙江台州

程序员应知道这十大面向对象设计原则

面向对象设计原则是OOPS编程的核心, 但我见过的大多数Java程序员热心于像Singleton (单例) . Decorator(装饰器).Observer(观察者) 等设计模式, 而没有把足够多的注意力放在学习面向对象的分析和设计上面.学习面向对象编程像"抽象"."封装"."多态"."继承" 等基础知识是重要的,但同时为了创建简洁.模块化的设计,了解这些设计原则也同等重要.我经常看到不同经验水平的java程序员,他们有的不

Java程序员提高效率的10+个最佳库

众所周知,Java 的生态环境相当庞大,包含了数量相当可观的官方及第三方库.利用这些库,可以解决在用 Java 开发时遇到的各类问题,让开发效率得到显著提升. 举些例子,最常用的官方库有 java.lang.java.util.java.io.java.sql.java.net 等:而至于目前最流行的第三方库,就有 Junit.SLF4J.Google Guava.XStream.JSoup.Gson.Joda Time 等,可以说是不胜枚举.  我到底需要用到哪些 Java 库呢?某些库再热门