重构第八章
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。如果两者关系是多对多,任意对象控制关联性都可以。
注意
重构必须在有单元测试的情况下,保证之前的功能修改后不收影响。切记!!!
网友评论