重构读书笔记-8_7-Change_Unidirectional

2019-06-28  本文已影响0人  MR_Model

重构第八章

7.Change Unidirectional Association to Bidirectional(将单向关联改为双向)

两个classes都需要使用对方的特性,但其中只有一条单向连接。添加一个反向指针,并使修改函数能够同时更新两条连接。

Example:

class Order...
    Customer getCustomer() {
        return _customer;
    } 
    void setCustomer(Customer arg) {
        _customer = arg;
    }
    Customer _customer;         //这是order类到Customer类的连接

Analyse:
示例中,Order class连接了Customer class。有时,你会发现Customer class中需要包含对Order class中的一些依赖。这个时候你可能需要在Customer class中添加一个对于Order class的连接。

Order和Cusomer都添加控制函数,重构之后,Order和Customer都可以互相控制连接。
End:

class Order...
    void addCustomer(Customer arg) {
        arg.friendOrders().add(this);       //Customer类中_orders添加本实例
        _customer.add(arg);                 //_customers 应该是Customer class集合添加新的Customer实例
    }
    void removeCustomer(Customer arg) {
        arg.friendOrders().remove(this);    //Customer类中_orders移除本实例
        _customer.remove(arg);              //_customers 应该是Customer class集合移除新的Customer实例
    }
class Customer...
    private Set _orders = new HashSet();
    Set friendOrders(){
        return _orders;                     //返回class实例的所有Order class
    }
    void addOrder(Order arg) {
        arg.addCustomer(this);              //Order class中添加Customer class的方法
    }
    void removeOrder(Order arg) {
        arg.removeCustomer(this);           //Order class中移除Customer class的方法
    }

Conclusion:

Change Unidirectional Association to Bidirectional(将单向关联改为双向)的方法,能够使得两个本来只含有一条连接的class,建立双向的连接。
实际使用当中,让单一的class来操控关联性,可以使得关联处理逻辑集中在一处:
1.如果两者之间是一对多关系,由单一的那一方承担控制者。
2.如果某个对象是另一个对象的组成,那么由后者负责控制关联性。
3。如果两者关系是多对多,任意对象控制关联性都可以。

注意

重构必须在有单元测试的情况下,保证之前的功能修改后不收影响。切记!!!
上一篇 下一篇

猜你喜欢

热点阅读