- 浏览: 1972796 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (509)
- JavaEE (122)
- Oracle数据库 (29)
- JavaScript (37)
- SAP (5)
- MySql数据库 (7)
- JavaSE (4)
- Ajax (1)
- jQuery (13)
- SSH框架 (36)
- Web Service (10)
- JSF框架 (2)
- JBPM (0)
- ireport报表 (2)
- ibatis (5)
- Hibernate (31)
- JSP (11)
- Tomcat 服务器 (20)
- Other (19)
- JavaWeb (4)
- Maven (11)
- OSWorkFlow (10)
- HTML (13)
- Exception汇总 (7)
- SVN (2)
- 笑话 (1)
- JSTL (1)
- WebSphere Message Broker (13)
- ANT命令 (3)
- Liunx (12)
- Struts2 (26)
- Eclipse (6)
- DOS (3)
- Flex (11)
- WebSphere (1)
- 开发常用工具 (3)
- Junit (2)
- EJB (4)
- Struts1.2 (2)
- Jboss (1)
- Android (2)
- Java框架源码解析 (1)
- Spring (4)
- MyBatis (6)
- SpringMVC (4)
- Jetty (2)
- 数据库表设计 (1)
- SSO (4)
最新评论
-
贝塔ZQ:
也可以试试PageOffice插件,觉得更简单点
Jxl操作Excel设置背景、字体颜色、对齐方式、列的宽度 -
jia1208:
...
Could not publish server configuration for Tomcat v6.0 Server at localhost. -
u011274527:
赞
java.io.EOFException java.io.ObjectInputStream$PeekInputStream.readFully 错误 -
旭旭小牛啦:
怎么没哟了,继续赛
jQuery 选择器 -
wzw3919:
100行会报空指针
Java 解压缩zip文件
1. DRY: 不要重复你自己(Don’t repeat yourself)
DRY是一条最容易理解但又是相对比较难以应用的原则。它是指当你在两处或者更多的地方发现相似代码时,我们应当把它们抽象成一个新的函数,在之前重复的地方调用新的函数并带上适当的参数。
DRY也许是最普遍的一条编程原则,我从未发现一个开发人员认为编写重复的代码是件好事。但是我发现一些开发人员在编写单元测试时忘记了这条原则,例如:设想一下你改变了一个类的接口,之前已经为这个类编写了很多的单元测试,如果你没有应用DRY原则,这时你需要手动去修改所有使用这个类接口的调用,来与每一个测试实例的新签名匹配。
2. 编写短小的函数/方法
有三个非常好的理由,选择编写短小的函数。
- 1. 代码会更容易阅读。
- 2. 代码会更容易重用(短小的函数更容易产生松耦合)。
- 3. 代码会更易于测试。
编者注:松耦合:在软件领域中,“耦合”一般指软件组件之间的依赖程度。耦合度松的软件会有较好的扩展性。
3. 给类、函数和变量使用好的命名
直接使用其他开发者的代码而不需要阅读说明文档,没有什么比这更好的事情了,因为代码中的类名、函数名已经能够告诉我们所有需要的信息。所以,采用这种方法,每次在为你的代码中任何元素进行命名的之前请花上几秒钟(思考),这会让大家的生活变得更轻松。
4. 为每个类分配正确的职责
一个类只承担一个职责(单一权责),听起来和有些人知道的SOLID原则很相似,但是这里不是指任意的职责,而是正确的职责。所以,如果我们要设计一个顾客类,我们不会给它创建一个销售的行为,我们只会让它处理所有与一个客户相关的数据。
编者注:SOLID:面向对象设计的五项原则 (是SRP单一职责原则、OCP开闭原则、LSP李式代换原则、ISP依赖反转原则和 DIP接口分离原则,首字符的缩写)。
5. 保持代码的条理性
代码条理性分两个层次
- 物理上的条理性:无论你采用了哪种结构,包、命名空间、文件夹等等,用一种更容易并且凭直觉就能找到代码存放在哪里的方式来组织你编写的类。
- 逻辑上的条理性:不论逻辑上从属关系如何,(只要有逻辑从属关系)类都应该能够互相访问彼此的成员变量,但是如果从属于不同的逻辑结构就应当只能通过接口来访问。这种逻辑分组通常会被实现成(逻辑)层、服务等。
6. 编写很多的单元测试
测试越多越好,它们是所有代码变动的安全保证,我们会在将来的某一天需要运行这些测试代码。
7. 尽早且经常地重构代码(Refactor often and sooner)
软件开发是一个持续发现的过程,为了编写保持与新增/改变的需求匹配的高质量代码,随着开发的进行,重构代码是必不可少的。由于重构是一项带有风险的任务,需要有两个主要的前提条件,来避免由于重构给系统引入新的错误。
- 1. 编写很多的单元测试
- 2. 每一次重构的幅度要比较小。在开发软件过程中,开始重构2000行代码,3个小时以后发现所有的代码都不能工作,并且导致问题的原因无从查找,因此需要恢复到最初版本,几乎没什么事能比这更让人抓狂了。
8. 注释是恶魔
这条特殊戒律有一点争议,我们大多数人学到的是“注释是一个好的习惯”,并且在一段晦涩的代码中有一段注释会比仅仅只有代码好的多,这里我的观点是:给晦涩的代码加注释还不如仅仅留下代码,只需要重构这段代码直到它变得可读为止。(编注:当然了,除了作者说的这种类型的代码,在其他情况下,还是得添加必要的注释,这不仅方便自己日后查看,更有利于后来者维护,请参阅《提高代码可读性的10个注释技巧 》一文。
9. 要面向接口编程,不要面向实现编程(Code to an interface, not to an implementation)
这是一条经典的原则,面向接口编程会让我们从实现的细节中解放出来,我们只要定义一个协议,并且依据协议调用定义的操作,期望(对方,即被调用的代码)能把实际的实现或者运行时态的实现传递给我们的代码。
10. 对代码进行复查
我们都会犯错误,没有什么能比请别人对我们代码做一个非正式快速复查更好的办法来查找错误了。最好不要等到代码都完成以后再复查,当某些重要部分的代码完成后,或者离上一次复查相隔几天之后,就进行复查。
发表评论
-
计算机常用英语单词
2014-10-06 09:14 0... -
程序员很少上《非诚勿扰》电视节目相亲之分析
2013-02-14 21:38 1844程序员很少上《非诚勿扰》电视节目相亲之分析 ... -
程序员与女朋友相处之道
2013-02-14 21:36 1136程序员与女朋友相处之 ... -
提示信息。
2012-08-14 00:34 9501. sorry, folder does not provi ... -
检测Java代码的常用工具
2012-05-03 20:28 1032findBugs 、 CheckStyle、 PMD、 ... -
Java多线程资料
2012-04-12 08:01 0多线程. -
面试 资料
2012-02-08 00:23 0阿斯顿发撒旦 阿斯顿 -
junit4单元测试实例
2012-01-04 08:35 1513单元测试 -
EDiary2.53 电子记事本
2011-11-22 10:14 1388EDiary2.53电子记事本 ,用于记录开发过 ... -
QQ表情图片
2011-11-02 22:29 0AAA -
Struts2+Ibatis+Spring框架
2011-11-02 02:45 1134下面是使用struts2+ibatis+spring整合的一个 ... -
IBM MQ API在线帮助文档
2011-10-12 14:52 2866IBM Websphere Message Queue MQ ... -
FastStone Capture 截图工具.
2011-10-10 18:22 974FastStone Capture 截图工具. -
使用Eclipse SVN将自己的项目添加到Google code上 搭建自己的代码仓库SVN
2011-09-05 00:37 1997使用Eclipse SVN将自己的项目添加到Google ... -
ant的一些学习资料
2011-08-02 00:35 1013阿什顿f啊撒地方按时 啊外人额外 -
帮助文档
2011-07-22 01:08 1104各种帮助文档。 -
项目图片
2011-07-19 00:45 1044图片 -
设计图
2011-07-12 22:46 1069aaaa -
绩效考核模板
2011-07-12 08:27 1657绩效考核模板一: 公司员工绩效考核表 总分: ... -
个人工作总结(转)
2011-06-03 00:13 1067个人工作总结 2010-0 ...
相关推荐
编好代码10条戒律
本文中列举了10个在Java编程中的重要规则。知道这些规则不重要,遵循这些规则才是最重要的。希望这些规则可以帮助大家成为更好更专业的编程人员。
你的 Joomla! 1.5 网站安全吗?你是否知道已经有很多 Joomla 网站被黑客攻击了?就连国内某著名 Joomla 知识网站前不久也惨遭...那么请认真阅读 —— Joomla 1.5 网站防黑9条戒律: Secure your Joomla! 1.5 website
解决问题的流程-8条戒律.pptx
详细介绍了Joomla!1.5网站防黑9条戒律:1.备份;2.对照“Joomla 管理员安全问题列表”补漏;3.用jSecure插件把后门关紧;4.及时更新Joomla核心到最新版本等等。
verilog RTL级代码编写指导(20篇精华文章)目录: Actel HDL Coding Style Guide; Advanced High-level HDL Design Techniques for Programmable Logic; Designing Safe Verilog State Machines with Synplify; ...
很受用的Web创业的10条戒律
不管什么程序开发,都需要有良好的编程习惯,一种好的习惯可以让你的代码可读性很高,同时,和你一起合作的同事也会感到很舒服。
本资料介绍了FPGA开发过程中优秀设计的十大戒律,可以帮助你设计出更加强壮的硬件程序,值得一读-This document describes the FPGA development process in the ten commandments excellent design can help you ...
优秀设计的十条戒律( The Ten commandment of Excellent Design )
Java开发者的十大戒律 Java开发者的十大戒律 Java开发者的十大戒律
Java开发者十大戒律 Java开发者注意事项
Java开发者的十大戒律
企业高效经理人的戒律.doc
酒店服务经典案例-清规戒律.docx
好的代码审查应该不是当代码完成的时候,而是在代码编写的过程中,不断地迭代代码审查。好的实践的,无论代码是否完成,代码审核需要几天一次地不断地进行。
本文档中介绍的零信任戒律建立在零信任核心原则的基础上,为零信任提供了一个不可协商的标准列表。 本文档的受众是商业、安全和IT领域的领导者,即高管们。文档中“戒律”源于并延伸自《 The Open Group白皮书:零...
网站推广执行中的八大戒律.doc