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

条款 33 :避免遮掩继承而来的名称,第1张

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

Avoid hiding inherited names.

我们先来看看什么是遮掩:

int x;
fun(){
    double x;
    cin>>x;
}

对于上面的代码来说我们输入的是double型的x,而不是int型的。因为他被遮掩了。

  1. C++的名称遮掩规则(name-hiding rules)所做的唯一事情就是:遮掩名称。至于名称是不是相同的类型并不重要。从上面的例子也能看出来。
  2. 我们来看看继承中的名称遮掩:
class base{
    private:
    	int x;
    public:
    	virtual void f1()=0;
    	virtual void f1(int);//mf1的重载
    	virtual void f2();
    	void f3();
    	virtual void f3(double);//重载
    	...
};
class Derived:public base{
    public:
    	virtual void f1();
    	// using base::f1;
    	//using base::f3
    	void f3();
    	void f4();
};


Derived d;
int x;
...
d.f1();//没问题,调用Derived::f1
d.f1(int x);//错误,因为Derived::f1遮掩了base::f1(带上using声明就没错了)
d.f2();//没问题,调用base::f2
d.f3();//没问题,调用Derived::f3
d.f3(int x);//错误,因为Derived::f3遮掩了base::f3(带上using声明就没错了)

上述代码中使用这么多类型 ,包括重载等只是为了强调一件事情:C++的名称遮掩 规则仅仅只进行名称的遮掩,关于其他的(例如返回类型,类型,是不是虚的,甚至参数等)都不考虑。如果你想在调用一个被覆盖的重载基类函数时,一个简单方法就是使用using声明,让本层能看见上层的相应东西。(参见上面注释代码)。

  1. 关于转交函数(forwarding functions),一种用于使名称可见的函数设计方式。这里就不介绍了。

请记住

  1. derived classes内的名称会遮掩base classes内的名称。在public继承下 从来没有人希望如此。
  2. 为了让被遮掩的名称在见天日,可以使用using声明或转交函数(forwarding functions)。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/4751558.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-08
下一篇 2022-11-08

发表评论

登录后才能评论

评论列表(0条)

保存