读书人

四个有害的java习气(转)

发布时间: 2012-12-26 14:39:29 作者: rapoo

四个有害的java习惯(转)

?

1.对局部变量(local variables),字段(fields),参数(method arguments)这三种变量的命名没有区分,造成了代码的阅读困难,增加了代码的维护成本。

?

作者举了个例子:

Java代码?
  1. public?boolean?equals?(Object?arg)?{??
  2. ??if?(!?(arg?instanceof?Range))?return?false;??
  3. ??Range?other?=?(Range)?arg;??
  4. ??return?start.equals(other.start)?&&?end.equals(other.end);??
  5. }??

?

在这个方法中,arg直接用argument的缩写,虽然大家一看就知道这是参数了,但这种命名方式却丢失了参数代表的对象本身的含义。大家知道这是参数,却不知道这是什么参数。如果方法的参数多一点,都按照arg1,arg2这样的方式命名,阅读代码的时候很头疼。另外两个字段变量,start和end,突然凭空而出,想一下才知道这应该是字段。当然,这个方法很短,造成的困难还不大,如果这个方法比较长的话,突然看到start和end两个变量,一般会先在前面找一下是不是局部变量,然后才能确定是类的字段变量。

?

这个问题貌似微不足道,但为什么要让代码阅读者花费额外时间在这些琐碎的问题上呢?如果有个方案能让代码阅读者一目了然的明白变量是那种变量,为什么不采用呢?就如同Steve McConnell在 《代码大全》中说的:"让人费神去琢磨神秘杀人凶手这没有问题,但你不需要琢磨程序代码,代码是用来阅读的。"


作者提出了解决方案:

读书人网 >编程

热点推荐