长久以来,看公司的项目代码都没感觉有啥问题,当然,本身也问题不大,只是认为换一种方式编写代码可能会更好;
//基类 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() { //不必调用基类同名函数,即便调用基类同名函数也不会有问题 // 子类做自己的处理 } };
优化之后的流程,子类重写虚函数,不必担心忘记调用基类的同名函数,只需要处理自己的流程即可,很明显,小小的改动,可以给逻辑开发人员省去不必要的忧虑。