先把定义的类列出来
class Base
{
public:
Base(int i = 0):val(i){}
int getVal(){return val;};
int getVal1(){return val;}
void print(){cout<<"base"<<endl;}
void getInt(){cout<<"do nothing"<<endl;}
virtual void getNum(){cout<<"基类原函数"<<endl;};
private:
int val;
};
class Derived1:public Base
{
public:
Derived1(int i = 0, int j = 1):Base(i),val(j){}
int getVal(){return val;}
void print(int i){cout<<"derived"<<endl;}
int getInt(int a){return a;}
void getNum(){cout<<"虚函数的重定义"<<endl;}
int getNum(int a){cout<<"这是一个新的函数"<<endl;}
private:
int val;
};
class Derived2:public Base
{
void getNum(int){cout<<"Derived2"<<endl;}
};
在C++中,名称的查找是由内自外的:对于一个派生类对象,先会在的派生类中查找名字,如果找到,就使用它;如果在它的作用域中找不到名字,就会在它的基类中查找:
Derived1 d;
//使用派生类的函数
cout<<d.getVal()<<endl;
//派生类没有找到,使用基类的函数
cout<<d.getVal1()<&l

本文探讨C++中基类与派生类的作用域规则,指出派生类可能会屏蔽基类成员,特别是同名成员。即使函数原型不同,也会发生屏蔽。重载函数在派生类中默认优先使用,但可以使用作用域操作符指定调用基类函数。而对于虚函数,由于动态绑定,会避免派生类的屏蔽,确保调用正确实现。
最低0.47元/天 解锁文章
540

被折叠的 条评论
为什么被折叠?



