笔记:条款33: 避免遮掩继承而来的名称

这是我在阅读Effective c++中认为比较重要的部分,下面给出了我对这一节的理解,并写出对应的比较容易理解的代码。

当发生继承时,如下所示,子类的mf1会遮挡父类中的mf1()和mf1(int), 编译器默认的行为是不允许父类中的重载函数派生到子类中,如果想在子类中使用父类中的重载函数,那么要在子类中使用using,本例中就是using A::mf1;

class A {
public:
	virtual void mf1() = 0;
	virtual void mf1(int) {
		cout << "A mf1" << endl;
	}
};
class B: public A {
public:
	void mf1() {
		cout << "B mf1" << endl;
	}
};

int main() {
	B b;
	b.mf1();
}

如果我们只想使用基类中的mf1(),那么using声明式在这里派不上用场,因为using声明式会令继承而来的某给定名称的所有同命函数都在派生类中可见,解决方法是提供一个转交函数。如下B类中的mf1就是转交函数。

class A {
public:
	virtual void mf1() = 0;
	virtual void mf1(int) {
		cout << "A mf1" << endl;
	}
};
class B: private A {
public:
	using A::mf1;
	void mf1() {
		A::mf1(1);
	}
};
int main() {
	B b;
	b.mf1();
}

请记住

继承类内的名称会遮掩基类内的名称。

为了让被遮掩的名称再见天日,可使用using声明式或转交函数。

猜你喜欢

转载自blog.csdn.net/lkq_primer/article/details/81122649