重构36计(2)

原文地址:http://www.cnblogs.com/west-link/archive/2012/04/16/2446951.html

第七计:串联函数调用

当一个类的大部分函数被较为频繁地调用,并且包含连续性地调用,那么可以考虑为这个类中那些没有返回值的函数增加返回值,即返回对象本身,这样就可以串联函数调用,使用起来较为方便,举个例子:

// 表示用户的类
public class User{
  public void setName(String name);
  public void setAge(int age);
  public void setPhoneNumber(int phoneNumber);
}

下面是不使用串联函数调用的情况:

User user = new User();
user.setName("West_Link");
user.setAge(3);
user.setPhoneNumber(122333);

下面是使用串联函数调用的情况:

User user = new User().setName("West_Link").setAge(3).setPhoneNumber(123333);

只需要为那些函数增加一个User对象的返回值即可,如下:

public User setName(String name){
   this.name = name;
   return this;
}

第八计:临时变量在用到时才声明

很多人喜欢在函数的开头把所有要用到的临时变量都声明了,我认为这种方式有以下几个缺点:

1、不利于代码的阅读,需要经常在变量的使用处和变量的声明处跳转,不方便。
2、容易造成资源的浪费,因为有些对象的初始化是比较耗费资源的,而函数可能在用到该对象之前返回。
3、不利于函数的拆分。
所以,我们应该尽可能降低临时变量的作用域,那样它能“捣乱“的范围就被缩至最小了。

第九计:保持类的公有函数粒度最小化

一个类的公有函数不应该过多,那样会使类变得臃肿、不易使用,我认为最佳状态是绝大部分公有函数不能被拆分,也就是说,不存在那些通过其他公有函数也能达到目的的函数,例如下面的类:

复制代码
public class StringArray{
  // 获取数组的大小
  public int getSize();
  // 判断数组是否为空
  public boolean isEmpty();
  // 将数据添加到数组的某个索引
  public void add(String value,int index);
  // 将数据添加到数组的末尾
  public void addToLast(String value);
  // 将数据添加到数组的起始位置
  public void addToFirst(String value);
}
复制代码

StringArray其实只需要两个公有函数即可,即getSize和add,因为isEmpty可以通过getSize来达到相同的目的:getSize() == 0。类似地,addToLast、addToFirst也可以通过add来实现。不过,如果类的公有函数比较少,而且类似isEmpty类似的需求经常被用到,那么保留这些公有函数还是值得的。

第十计:将可访问性降至最低

面向对象中的封装性使得我们可以隐藏类或者接口的实现细节,所以,为了让程序更易维护、接口或者类的使用更加简单,我们应该尽可能降低成员变量或者成员函数的可访问性,辅助函数一定要声明为私有的,确保只将接口函数声明为公有的,如果该辅助函数可能会被子类用到,则可以声明为保护的。辅助类也应声明为私有的,对于成员变量则一定要声明为私有的,只提供必要的set或者get函数。总之,当我们增加新的类、成员变量、成员函数时,一定要合理地设置可访问性,暴露给外界的越少越好。

第十一计:合并条件减少嵌套

条件判定如果嵌套的太多会大大降低程序的可读性,很容易滋生Bug,例如:

复制代码
if(a){
  if(b || c){
      if(d){
          ...
       }
   }
}
复制代码

可以合并成:

if(a && (b || c) && d){
     ...
}

第十二计:循环中早用continue减少条件嵌套

除了通过合并条件来减少嵌套层次外,在for或者while循环中,可以用continue来减少条件嵌套,例如:

复制代码
for(int i=0; i<100;i++){
   if(a){
      if(b){
          if(c){
               ...
          }
       }
    }
}
复制代码

这段代码的嵌套深度是4,使用continue可以大大减少嵌套层次:

复制代码
for(int i=0; i<100;i++){
  if(!a)
     continue;
  if(!b)
     continue;
  if(!c)
     continue;
   ...
}
复制代码


你可能感兴趣的:(重构)