Remove Middle Man (移除中间人)

Summary: 

某个类做了过多的简单委托动作。让客户直接调用受托类。

Motivation:

“封装受托对象”有其好处,但是这层封装也是要付出代价:每当客户要使用受托类的新特性时,就必须在服务端添加一个简单委托函数。随着受托类的新特性越来越多,服务类完全变成了一个“中间人”,此时就应该让客户直接调用受托类。

Mechanics: 

1.建立一个函数,用以获得受托对象。

2.对于每个委托函数,在服务类中删除该函数,并让需要调用该函数的客户转为调用受托对象。

3.处理每个委托函数后,编译、测试

范例

        我们将使用之前用过的“人与部门”的例子。在上一项重构(Hide Delegate)结束时,Person将Department隐藏起来,为找出某人的经理,客户代码可能这样写

manager = john.getManager();
像这样,使用和封装Department都很简单。但如果大量函数都这么做,我们就不得不在Person之中安置大量委托行为。这就该是移除中间人的时候了。首先在Person中建立一个函数用于获得受托对象:

public class Person
{
    Department department;

    public Department getDepartment()
    {
        return department;
    }
...
}
然后逐一处理每个委托函数。针对每一个这样的函数,找出通过Person使用的函数,并对它进行修改,使它首先获得受托对象,然后直接使用后者:

manager = john.getDepartment().getManager();
然后我们就可以删除Person的getManager()函数。如果遗漏了什么,编译器会告诉我们。

你可能感兴趣的:(Remove Middle Man (移除中间人))