清除代码异味
来源:外刊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?)
关于学习:在用户组里跟其它人合作,交流,讨论。你并不能学到所有的东西,但要努力缩小自己的“你不知道你不知道的东西”,让它成为“你知道你不知道的”


猜你喜欢
- 什么是M2det目标检测算法一起来看看M2det的keras实现吧,顺便训练一下自己的数据。常见的特征提取方法如图所示有SSD形,FPN形,
- <?php //本功能主要是利用文件修改时间函数filemtime与现在时间作减法判断是否更新内容。 $cahetime=2;//设置
- 1.ROOT_URLCONF = '总路由所在路径(比如untitled.urls)'<===默认情况是这样根路由的路
- 本文实例讲述了微信小程序时间轴实现方法。分享给大家供大家参考,具体如下:最近项目需要在页面上做一个时间轴,又是第一次做,而且还是在小程序上,
- DataFrame是一个组织成命名列的数据集。它在概念上等同于关系数据库中的表或R/Python中的数据框架,但其经过了优化。DataFra
- 一. 介绍一个计数器工具提供快速和方便的计数,Counter是一个dict的子类,用于计数可哈希对象。它是一个集合,元素像字典键(key)一
- 本文实例讲述了python比较两个列表是否相等的方法。分享给大家供大家参考。具体如下:这里演示了 == 和 is两种方法的区别:L1 = [
- vue动态绑定class练习。:class=“{ ‘类名1':条件表达式,‘类名2':条件表达式… }”<templa
- 在新的公司开始上班,今天工作的主题内容是市场部门需要抓取一些论坛用户的邮箱,以便发送营销邮件。于是用了一个python脚本来执行,前面抓了几
- 本文给出一条 SQL 语句用于展示在同一名服务器上,不同的数据库间查询,注意当前连接用户要对两个库都有权限SQL Server 中 SQL
- 经常用mysql的人可能会遇到下面几种情况:1、我字段类型是not null,为什么我可以插入空值2、为什么not null的效率比null
- 地图这期文章我们一起来看看地图是如何绘制的,如何在地图里面添加数据进行多维度的展示,下面我们一起来感受一下地图的魅力吧!&ldquo
- 这是由十几位视觉设计师设计的挂历,每个月份都是不同的风格,就像每个月都有不同温度和心情一样,思维跳跃性很大,可以作为挂历设计参考。当然,如果
- 应用场景在嵌入式开发中,常常需要将一个binary文件分割成多个文件,或者将一个binary的某块区域抓成一个单独文件。本篇blog以pyt
- 列表解析——用来动态地创建列表[expr for iter_var in iterable if cond_expr]例子一:map(lam
- 上午在分析索引的使用情况,想看一下数据库什么时候启动的,确保统计的数据没有问题,可以使用下面三种方法查询:--2008及之后版本才有SELE
- 数据类型是每种编程语言必备属性,只有给数据赋予明确的数据类型,计算机才能对数据进行处理运算,因此,正确使用数据类型是十分必要的,不同的语言,
- 我们都知道ACCESS是ASP的亲密伙伴。因为两种最简单的东西碰在一起总能迸发出火花。然而,当我们过滤不严格的时候经常出现日文字符,这个时候
- 一、mysql中实现指定排序需求一般情况下,我们排序都是直接利用 order by 字段 asc/desc;但是如果要排序的字段数据格式并不
- 大家知道,Microsoft为了更好地预防恶意用户和攻击者的攻击,在默认情况下,没有将 IIS6.0 安装到 Windows Server