代码才是最好的注释

 一直以来都存在代码注释的作用的讨论。很多人认为注释是不必要的,写注释那是因为代码可读性太差了。我也同意这个原则。如果必须添加注释,我觉得可以添加一些解释代码为什么,而不是做什么的注释。下面我举个例子说明该如何除去代码中的注释。

    我们直接看代码,下面的代码是我要对注释进行清除的例子。(这段代码只是作为一个例子,没有做过多的考虑。)

复制代码
1  public  String recommendGift( double  budget){ 
2  //  get gifts from helper 
3  String[] gifts  =  giftHelper.getGifts(); 
4  String gift  = null
5 
 6  for  ( int  i  = 0 ; i  & lt; gifts.length; i ++ ) { 
7 
 8  gift  =  gifts[i]; 
9 
10  //  find out if gift already given 
11  boolean isAlreadyGiven  = false
12  for  (String given : giftsGiven) { 
13  if (gift.equals(given)){ 
14  isAlreadyGiven  = true
15  break
16 
17 
18 
19  //  calculate rating and budget 
20  int  x  =  rating  * 200
21  boolean ok  =  budget  & lt; x; 
22 
23  //  if both conditions satisfy, give it. 
24  if ( ! isAlreadyGiven  & amp; & amp; ok){ 
25  giftsGiven.add(gift); 
26  //  increment maintenance cost of the girlfriend 
27  maintenanceCost  +=  budget; 
28  return  gift; 
29 
30 
31 
32  return  gift; 
33  }
复制代码

这段代码是相当简单的。从礼物清单中挑选出不在已赠送的礼物列表中的而且不超过预算的第一份礼物。这段代码有如下几个问题:

1、方法过长

2、这个方法做的事情太多

3、可读性差,即使加了注释

4、注释告诉我们代码是干什么的,这些应该是代码自己的事情才对。

让我们开始整理一下这段代码。

首先,看下面代码段,非常明显,这些代码注释是不必要的。这种代码注释我们应该避免。它并没有提高代码的可读性,事实上起到了相反的效果。

//  get gifts from helper 
String[] gifts  =  giftHelper.getGifts();

接着,我将下面带注释的代码移动到一个分离的方法中。方法的命名可以来自给出的注释。

复制代码
//  find out if gift already given 
boolean isAlreadyGiven  = false
for  (String given  in  giftsGiven) { 
if (gift.equals(given)){ 
isAlreadyGiven 
= true
break

}
复制代码

修改后的代码:

复制代码
private  boolean isGiftNotAlreadyGiven(String gift) {
boolean isAlreadyGiven 
= true ;
for  (String given  in  giftsGiven) {
if (gift.equals(given)){
isAlreadyGiven 
= false ;
break ;
}
}
return  isAlreadyGiven;
}
复制代码

然后按照相同的方式继续下去,最终的代码如下:

复制代码
public  String recommendGift( double  budget)
{
String recommendedGift 
= null ;
for  (String gift  in  giftHelper.getGifts()) 
{
recommendedGift 
=  gift;
if (isGiftNotAlreadyGiven(recommendedGift) && isUnderBudget(budget))
{
updateMaintenanceCostAndGiftsGiven(budget, recommendedGift);
return  recommendedGift;
}
}
return  recommendedGift;
}

private void  updateMaintenanceCostAndGiftsGiven( double  budget, String gift)
{
giftsGiven.add(gift);
maintenanceCost  +=  budget;
}

private  boolean isUnderBudget( double  budget)
{
int  x  =  rating  * 200 ;
boolean ok 
=  budget  <  x;
return  ok;
}

private  boolean isGiftNotAlreadyGiven(String gift) 
{
boolean isAlreadyGiven 
= true ;
for  (String given  in  giftsGiven) {
if (gift.Equals(given)){
isAlreadyGiven 
= false ;
break ;
}
}
return  isAlreadyGiven;
}
复制代码

这里有几件需要注意的事情:

1、一个大方法按照它的功能被分割成几个小方法,这样代码就比较容易阅读了。

2、每个方法大概4到5行,非常理想!

3、注释去掉了,但是目的却达到了。用代码来代替了注释。

译自:Better way to comment.. code it.

译者说明:

1、文章的那段代码很有特色,正在恋爱的男程可以试一下代码里面的方法。

2、确实用代码来代替了注释。

3、从文章可以看到这段代码的演变主要是将注释变成了函数名和变量名。

4、对于老外来说,英文和代码类似,所以这样做就非常受用,通过看函数名,变量名就能明白函数的功能,Clean Code书中也是这样建议的。

5、对我们来说第一语言是中文的,英语不好情况就不一样了,这就是为什么国人的建议大多要求注释详尽,让代码更易读易懂;而老外的建议几乎是尽可能的少。

6、我建议符合我们的国情:尽可能多的注释。





本文转自麒麟博客园博客,原文链接:http://www.cnblogs.com/zhuqil/archive/2010/10/30/1864882.html,如需转载请自行联系原作者


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值