长久以来,看公司的项目代码都没感觉有啥问题,当然,本身也问题不大,只是认为换一种方式编写代码可能会更好;
直接看实例和优化
//基类
class CBase {
//重写该方法时,需调用基类同名函数
virtual void OnDoing() {
//基类做了某些处理
}
};
//子类
class CSub:public CBase {
virtual void OnDoing() {
__super::OnDoing();
// 子类做自己的处理
}
};
子类重写基类的虚函数,往往会要求调用基类的同名函数,而如果开发人员一旦忘记调用,则可能引起一系列问题,甚至找不出问题根源,那么优化下,改成以下流程:
//基类
class CBase {
void OnDoBase() {
//基类做了某些处理
......
OnDoing();
}
virtual void OnDoing() {
//这里什么都不做,只让子类重写
}
};
//子类
class CSub:public CBase {
virtual void OnDoing() {
//不必调用基类同名函数,即便调用基类同名函数也不会有问题
// 子类做自己的处理
}
};
优化之后的流程,子类重写虚函数,不必担心忘记调用基类的同名函数,只需要处理自己的流程即可,很明显,小小的改动,可以给逻辑开发人员省去不必要的忧虑。
适合底层库为上层逻辑开发提供支持时使用,如果是同一个人编写的逻辑,就无所谓了