重构 — 改善既有的类图设计 条款14:将多个继承类对外部的依赖上移至基类
黄国强 2008-12-29
首先看图一。
图一
图一中,类2、类3和类4都是从类1继承。它们同时依赖于类5。这张图第一感觉就是不好看,因为有交叉存在。重构也很简单,正如题目所言,将外部的依赖上移至基类就解决了这个问题。如图二所示。
图二
下面用代码来说明这个重构。
class Class5
{
};
class Class1
{
};
class Class2 : public 1
{
...
private:
Class5 * m_pClass5;
public:
void SampleFunc(void)
{
m_pClass5->Func();
}
...
};
这是重构前的代码,重构后变成这个样子。
class Class1
{
protected:
void CallClass5Func(void)
{
m_pClass5->Func();
}
private:
Class5 * m_pClass5;
};
class Class2 : public Class1
{
...
void SampleFunc(void)
{
Class1::CallClass5Func();
}
...
};
这个重构达到的效果是,Class2对Class5的调用都是通过Class1来实现的。好处是Class2与Class5脱钩,未来Class5的变化只有Class1知道,Class2、Class3和Class4对此一无所知的,故不必修改;