清除代码异味
来源:外刊IT评论 发布时间:2011-05-21 08:34:00
方法组成模式
方法里的所有语句都必须处在同一个归纳层次上
无用的注释
让代码自我表白
标注为什么这样,而不是如何这样
对方法表现进行描述等于重复表现
这样的注释等于重复写一遍代码
i += 1 // 递增
长方法里用来描述这个方法有不同的功用的注释
把里面的功能片段提取成小方法 & 删除注释
IDE排泄物:IDE自动产生的注释空白占位符
糟糕的注释通常产生于TDD*
* (TDD:Threat driven development,恐吓驱动开发)—— 你应该为方法的表象写注释,你应该为长方法写注释,等
产品里的注释:
// 上帝保佑,我实在不知道这是什么意思
变量名称
使用能表意的名称
不要用单个字母做名称
也不要使用太长的名称
继承
继承更多的是被滥用了
组合通常优于继承
在一对一关系中使用继承,满足Liskov替换原则
不要用继承来实现方法重用
重用方法时,委托是个更好的选择
粘手的语言
这种语言更容易导致犯错误
最臭的代码
冗长的类
重复的代码
淘汰的方法
不必要的塑型(cast)
过度使用设计模式
代码除味
代码复查!
写出之后尽快进行
要增量进行
要复查测试用例
可使用结对编程
但要保持结对伙伴的经常变动,否则你会习惯你的气味,不再会有察觉
结对伙伴一、两天调换一
一些设计原则
一些参考书籍
问和答
关于使用代码检测工具,例如PMD:这样的工具非常的有用,它能让你捕捉到很直接的问题,使你的代码复查工作专注于高层面的设计原则问题
关于IDE上附加的工具:不要自己去运行它们。让这些工具在后台自动的运行(或智能化)
动态语言里需要重构吗:动态语言里没有太多的自动重构工具,但程序员仍然应该手动的重构
关于动态语言的设计模式:每种语言都有自己的模式和特色。例如:smalltalk的execute around method模式
关于掌握多种语言
你应该知道处理一个问题的多种范式,多种风格和多种方式
一种语言中学到的特色方法应用到其它语言里
知道各种不同方式的各自风险
关于编程语言趋势:对函数性编程,移动设备编程兴趣浓厚
关于著书:长时间的思考书中的各项主题,多做这方面话题的讨论,吸取精华。当开始动手去写时,已经胸有成竹,2周内把书写成
关于思考文献:思考文献很有用,但你也要多看看批评性的思考性文章,它们是关于你如何去思考的(double loop learning?)
关于学习:在用户组里跟其它人合作,交流,讨论。你并不能学到所有的东西,但要努力缩小自己的“你不知道你不知道的东西”,让它成为“你知道你不知道的”
猜你喜欢
- jQuery是最近比较火的一个JavaScript库,从del.icio.us/上相关的收藏可见一斑。到目前为之jQuery已经发布到1.2
- HTML 5 和 XHTML 2规范草稿公布以来,一直存在很大的争议。HTML 5是由包括Google、Mirosoft、Mozilla、O
- 代码如下:<%@LANGUAGE="VBSCRIPT" CODEPAGE="936"
- 数据库复制:简单来说,数据库复制就是由两台服务器,主服务器和备份服务器,主服务器修改后,备份服务器自动修改。复制的模式有两种:推送模式和请求
- 1、终极方法:条件注释<!--[if lte IE 6]> 这段文字仅显示在 IE6及IE6以下版本。 <![endif]
- 页面大小、窗口大小和滚动条位置这三个数值在不同的浏览器例如Firefox和IE中有着不同的实现。即使在同一种浏览器例如IE中,不同版本也有不
- 浏览带有下拉菜单的网页时,我们经常会注意到当更改显示器分辨率时,其下拉菜单的位置并没有改变,这也是我们设计网页时容易忽略的一个问题,其实通过
- 如何用ASP获知机器的网络配置?看看我们的例子:Option Explicit Dim WSHShell&nb
- 其主要的优点便是无需再手工添加大量的信息了,可以指定对某一个站信息的截取进行批量录入,达到省时省力的目的。与其单纯的ASP小偷程序不同的是:
- 学习编写简练、优化的CSS需要大量的实践和一种不自觉的强迫性清洁的渴望。然而让你的CSS保持整洁并不仅仅是你对清洁的疯狂的心理需求,尤其对于
- JavaScript 读取、删除 Cookie 的函数* * WebFXCookie class */ fun
- 最简单的:<textarea name="A" cols="45" rows="2&
- 有时候想为我们的网页提供多语言支持,如果一种语言用一张网页来做实在太麻烦了,幸好Google提供了语言工具功能,下面介绍如何利用它来实现网页
- System.Data.OleDb.OleDbDataAdapter与System.Data.OleDb.OleDbDataReader的区
- 用QQ聊过天的朋友都对它的自动隐藏窗口功能爱不释手,它可以使窗口显得清爽整洁而且富有动感,笔者的几个朋友都想在自己的网页中加入类似的东东,经
- 问题:数据库实际大小为600MB, 日志文件实际大小为33MB, 但日志文件占用空间为2.8GB!试了多种方式,SHIRNK DATABAS
- 摘要:随着应用领域的不断拓展和多媒体技术, 人们发现关系数据库的许多限制和不足,因而数据库技术进入了“后关系数据库时代”。文件数据库由此应运
- (5)SELECT (5-2) DISTINCT(5-3)TOP(<top_specification>)(5-1) <s
- 这篇论坛文章主要介绍了Oracle数据库到SQL Server数据库主键的迁移过程,具体内容请参考下文。由于项目需要要将以前Oracle的数
- asp代理采集代码如下:<%Function ProxyPage(url) Set Retrieval&