虚函数的实现机理

面试官问道的一个问题,当时没想出来,说不清楚。挂掉电话突然想到应该就是函数指针的问题。

个人想法:父类定义的虚函数根本问题在于函数指针,默认指向父类实现代码段,子类重写后则指向子类的代码段。如此便实现了虚函数机制,为了求证我的理解是否正确,因此查了资料。此处做个记录。

理解:

通过查资料简单理解就是 一个类有一个顺序存放的虚函数的地址表,顺序是声明顺序。并且虚函数表的指针存在于对象实例中最前面的位置,这样通过对象实例的地址得到这张虚函数表,然后就可以遍历其中函数指针,并调用相应的函数。

如果A是父类,有fun1,fun2,fun3三个虚函数,子类B继承A切没有重写虚函数,那么子类对象虚函数表是Afun1,Afun2,Afun3,Bfun1,Bfun2,Bfun3,加一个结束标记。如果子类B重写了虚函数fun2,那么对象虚函数表则是Afun1,Bfun2,Afun3,Bfun1,Bfun3,加一个结束标记。这样在运行时调用fun2从虚函数表中取到的函数指针是Bfun2,这样就完成了多态。

参考资料链接:虚函数实现原理_微积粉的博客-CSDN博客_虚函数的实现原理

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值