📜  当对C++中的派生类方法进行更严格的访问时,会发生什么情况?

📅  最后修改于: 2021-05-25 23:27:16             🧑  作者: Mango

我们在这里讨论了Java的类似主题。与Java不同,C++允许对派生类方法进行更严格的访问。例如,以下程序可以正常编译。

#include
using namespace std;
  
class Base {
public:
    virtual int fun(int i) { }
};
  
class Derived: public Base {
private:
    int fun(int x)   {  }
};
  
int main()
{  }

在上面的程序中,如果我们将main()更改为以下代码,则会得到编译器错误,因为fun()在派生类中是私有的。

int main()
{
    Derived d;
    d.fun(1);
    return 0;
}

那下面的程序呢?

#include
using namespace std;
  
class Base {
public:
    virtual int fun(int i) { cout << "Base::fun(int i) called"; }
};
  
class Derived: public Base {
private:
    int fun(int x)   { cout << "Derived::fun(int x) called"; }
};
  
int main()
{
    Base *ptr = new Derived;
    ptr->fun(10);
    return 0;
}

输出:

Derived::fun(int x) called 

在上面的程序中,私有函数“ Derived :: fun(int)”通过基类指针被调用,该程序运行良好,因为fun()在基类中是公共的。访问指定符在编译时检查,并且fun()在基类中是公共的。在运行时,仅调用与指向的对象相对应的函数,并且不检查访问说明符。因此,派生类的私有函数通过基类的指针被调用。

要从最佳影片策划和实践问题去学习,检查了C++基础课程为基础,以先进的C++和C++ STL课程基础加上STL。要完成从学习语言到DS Algo等的更多准备工作,请参阅“完整面试准备课程”