C++多态下的访问修饰符

C++多态下的访问修饰符

先上代码:

class Parent
{
public:
    virtual void showMsg()
    {
        cout << "Parent showMsg()" << endl;
    }
};

class ChildA : public Parent
{
public:
    void showMsg() override
    {
        std::cout << "ChildA showMsg()" << std::endl;
    }
};

class ChildB : public Parent
{
private:
    void showMsg() override
    {
        std::cout << "ChildB showMsg()" << std::endl;
    }
};

在这段代码里我们先定义了一个Parent类,然后定义了2个继承于它的子类ChildA和ChildB。

我们在Parent类中声明且实现了一个名为showMsg()的函数,且此函数为虚函数,允许子类重写。我们在子类ChildA和ChildB中均重写了此函数,唯一不同的是ChildA中showMsg()函数的访问修饰符为public,ChildB中showMsg()的访问修饰符为private。我们知道public和private两个访问修饰符的区别是,public修饰符下函数允许外部访问,而private修饰符下的函数不允许外包访问(当然友元函数和友元类可以访问)。

我们测试一下:

int main()
{
    ChildA* cA = new ChildA;
    cA->showMsg();

    ChildB* cB = new ChildB;
    cB->showMsg();


    delete cB;
    cB = nullptr;

    delete cA;
    cA = nullptr;

    return 0;
}

编译报错:
1310340-20190612093407997-1952527827.png

很显示然编译器提示我们,对于ChildB类,showMsg()函数是私有的,不能访问。

我们修改一下测试代码:

int main()
{
    ChildA* cA = new ChildA;
    cA->showMsg();

    Parent* cB = new ChildB;
    cB->showMsg();

    delete cB;
    cB = nullptr;

    delete cA;
    cA = nullptr;

    return 0;
}

再编译一下代码,代码通过编译,我们运行一下。

1310340-20190612093431938-1524917854.png

可以看到实例化对象cB调用了类ChildB的showMsg()函数。ChildB的showMsg()函数不是私有的吗,为什么可以调用呢?

其实通过上面测试不难看出,对于C++的访问修饰符public、protected、private来说,所谓的访问修饰只是在编译器有效,编译时编译器会根据访问修饰符,检测外部调用是否合法,不合法则报错。在运行期是不做访问权限检查的,因此在多态下,子类继承于父类具有多态性质的函数,只要父类的中的访问修饰符为public, 子类中的访问修饰符不论是public,还是private,都是可以通过父类指针的形式去访问的。

转载于:https://www.cnblogs.com/chengjundu/p/11007742.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值