没有一个范围分辨率的预选赛identify()会默认在当前类的identify(),可得出::identify()。这将导致来源::identify()调用自身,这将导致一个无限循环!
隐藏功能
在C++中,它是不可能从一类的删除功能。然而,它是可以隐藏的现有功能。
正如上面提到的,如果你重新定义一个函数,它可以使用任何访问说明符是宣布在派生类中的。因此,我们可以定义一个公共函数作为我们的派生类的私有,和公众将失去它。然而,C++也给我们改变基座构件的可访问派生类中定义的成员甚至没有能力!这是通过简单地命名成员完成(使用范围解析操作符)有它的派生类中的访问改变新的访问说明符下。
例如,考虑下面的基地:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
class Base
{
private:
int m_nValue;
public:
Base(int nValue)
: m_nValue(nValue)
{
}
protected:
void PrintValue() { cout << m_nValue; }
请注意,这允许我们要设计一个合理的基类和派生类封装了它在我们的数据。
(或者,而不是继承基地成员公开和通过重写它的访问说明符,使我们可以继承的基础m_nvalue私人私人,这将导致所有的基地成员先私下继承)。
一句忠告:你只能改变访问说明符的基地成员的类通常可以访问。因此,你不能改变访问说明符的底座构件从私人到受保护的或公共的,因为派生类不能访问基类的私有成员。