同名隐藏

本文介绍了C++中不同作用域声明的标识符可见性原则,特别是同名隐藏在继承中的应用。当派生类声明与基类同名的属性或函数时,基类的相应成员会被隐藏。同时,探讨了函数的重载、重定义(隐藏)和重写(覆盖)的概念,重载要求同一作用域内的函数名和参数列表唯一,重定义(隐藏)涉及派生类中不同参数列表的同名函数,而重写(覆盖)则需要基类函数为virtual,并且在派生类中具有相同的函数签名。
摘要由CSDN通过智能技术生成

同名隐藏

不同作用域声明的标识符的可见性原则:

若存在多个具有包含关系的作用域,外层声明了一个标识符 ,①内层没有再声明同名标识符,那么外层的标识符在内层依然可见。②内层声明了同名标识符,则外层标识符在内层中不可见。

这种即为隐藏规则。

同名隐藏在继承中的体现:

在类的派生中,基类成员和派生类成员都有类作用域,二者是相互包含的两层,派生类在内层。所以若派生类声明了与基类同名的新属性/新函数(即使参数表不同),则触发了隐藏规则。(从基类继承的同名函数的所有重载形式也被隐藏)

若要访问被隐藏的成员,需要用作用域分辨符::和基类名来限定。

//demo1 属性的同名隐藏
class Parent
{
public:
    int m;
    Parent()
    {cout<<"Parent():"<<"&m="<<&m<<endl;}
};
class Child:public Parent
{
public:
    int m;
    Child()
    {cout<<"Child():"<<"&m="<<&m<<endl;}
};
main
{
    Child c;
    c.m=100;
    c.Parent::m=1000;
    cout<<"&c.m="<<&c.m<<endl;
    cout<
同名隐藏同名覆盖都是指在类的继承中,派生类中定义了与基类同名的成员函数或变量的情况。它们的区别主要在于访问基类同名成员的方式和效果不同。 同名隐藏是指当派生类中定义了与基类同名的成员函数或变量时,基类同名成员就被隐藏了,即在派生类中无法直接访问基类同名成员。如果需要访问基类同名成员,可以通过作用域解析运算符 `::` 来访问,例如: ```cpp class Base { public: int x; void func(); }; class Derived : public Base { public: int x; void func(); }; void Derived::func() { // 在派生类中访问基类同名变量 x Base::x = 1; // 在派生类中访问基类同名函数 func Base::func(); } ``` 同名覆盖是指派生类中定义的同名成员函数或变量覆盖了基类同名成员,即派生类中的同名成员与基类同名成员具有相同的名称和类型,但是派生类中的同名成员会覆盖基类同名成员。例如: ```cpp class Base { public: int x; void func(); }; class Derived : public Base { public: int x; void func(); }; void Derived::func() { // 在派生类中访问派生类同名变量 x x = 1; // 在派生类中访问派生类同名函数 func func(); } ``` 在同名覆盖的情况下,如果需要访问基类同名成员,可以使用作用域解析运算符 `::` 显式地指明要访问基类同名成员,例如: ```cpp void Derived::func() { // 在派生类中访问基类同名变量 x Base::x = 1; // 在派生类中访问基类同名函数 func Base::func(); } ``` 总之,同名隐藏同名覆盖都是继承中的重要概念,需要理解它们的区别和使用方式。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值