[16] Middle Man(中间人)

duiwe对象的基本特征之一就是封装---对外部世界隐藏其内部细节.
封装往往伴随着委托. 比如你问你的主管是否有时间参加一个会议, 他就把这个消息 "委托" 给他的记事簿, 然后才能告诉你. 很多, 你没有必要知道这位主管到底使用的是传统记事簿还是电子记事簿亦或是秘书来记录自己的约会.

但是人们可能过度运用委托. 你也许会看到某个类接口有一半的函数都委托给了其他的类, 这样就是过度运用. 这时候应该运用 Remove Middle Man(移除中间人) , 直接和真正负责的对象打交道. 如果这样"不干实事"的函数只有少数几个, 可以运用InlineMethod(内联函数) 把它们放进调用端. 如果这些Middle Man还有其他的行为, 可以运用Replace Delegation With Inheritance(用继承取代委托) 把它变成实责对象的子类, 这样你既可以扩展原对象的行为, 又不必负担那么多的委托动作.

Tips:


这节和15节是相反的两种情况, 过度的隐藏委托关系,就会造成本节的Middle Man, 所以Remove Middle Man 其实也就是Hide Delegate(隐藏委托关系) 反向操作.

你可能感兴趣的:([16] Middle Man(中间人))