虚函数和友元

#include<iostream>
using namespace std;
class A ;
class B
{
    void print(){cout<<"B::print"<<endl;}
public:
    friend class A;
};
class A
{
public:
    void fun(B b){b.print();}
};
class D:public B
{
    void print(){cout<<"D::print"<<endl;}
};
int main()
{
    D d;
    A a;
    a.fun(d);
    return 0;
}

程序的执行结果为 B::print

看上去 友元函数并没有被继承,仅仅是派生类对象当成了一个基类对象来用 因此输出 B::print

若将上述print 函数改为虚函数并通过多态来访问,就可以达到类似于友元可以继承的结果

#include<iostream>
using namespace std;
class A ;
class B
{
    virtual void print(){cout<<"B::print"<<endl;}
public:
    friend class A;
};
class A
{
public:
    void fun(B *pb){pb->print();}
};
class D:public B
{
    virtual void  print(){cout<<"D::print"<<endl;}
};
int main()
{
    D d;
    A a;
    a.fun(&d);
    return 0;
}

输出结果为 D::print

A 明明只是B的友元 但却通过类型转换 就可以访问D类的那个私有成员 看似 友元关系被继承了

因为 友元  的判断,在编译器决定 而虚函数在运行期间进行绑定。在编译友元类A中成员函数 func 时 编译器看到 *pb 的类型是B 而A是B的友元 所以允许它调用B::print

而在运行时,由于print 函数是虚函数,所以最终运行时被确定执行 D::print  这是c++ 众多特性 “正交” 现象之一,一个编译器属性与一个运行期属性相遇。友元函数的作用提高了程序的执行效率,即减少了类型检查和安全检查等需要的时间开销,使得非成员函数可以访问类的私有成员,而虚函数的作用则是为了实现多态。

友元和虚函数结合能变相实现 友元关系的继承

转载于:https://www.cnblogs.com/guoyu1024/p/9069956.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值