重构36计(7-12)

[b]第七计:串联函数调用[/b]
当一个类的大部分函数被较为频繁地调用,并且包含连续性地调用,那么可以考虑为这个类中那些没有返回值的函数增加返回值,即返回对象本身,这样就可以串联函数调用,使用起来较为方便,举个例子:
// 表示用户的类
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;
}

[b]第八计:临时变量在用到时才声明[/b]
很多人喜欢在函数的开头把所有要用到的临时变量都声明了,我认为这种方式有以下几个缺点:
1、不利于代码的阅读,需要经常在变量的使用处和变量的声明处跳转,不方便。
2、容易造成资源的浪费,因为有些对象的初始化是比较耗费资源的,而函数可能在用到该对象之前返回。
3、不利于函数的拆分。
所以,我们应该尽可能降低临时变量的作用域,那样它能“捣乱“的范围就被缩至最小了。

[b]第九计:保持类的公有函数粒度最小化[/b]
一个类的公有函数不应该过多,那样会使类变得臃肿、不易使用,我认为最佳状态是绝大部分公有函数不能被拆分,也就是说,不存在那些通过其他公有函数也能达到目的的函数,例如下面的类:
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类似的需求经常被用到,那么保留这些公有函数还是值得的。

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

[b]第十一计:合并条件减少嵌套[/b]
条件判定如果嵌套的太多会大大降低程序的可读性,很容易滋生Bug,例如:
if(a){
if(b || c){
if(d){
...
}
}
}

可以合并成:
if(a && (b || c) && d){
...
}

[b]第十二计:循环中早用continue减少条件嵌套[/b]
除了通过合并条件来减少嵌套层次外,在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;
...
}


ref:http://blog.csdn.net/m13666368773/article/details/7472209
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值