虚函数的实现原理学习

#include <cstdio>
#include <iostream>
using namespace std;

class Base{
	public:
	void Function() 
	{
		cout << "This is Base Function" << endl;
	}
	virtual void Function1() 
	{
		cout << "This is Base Function1" << endl;
	}
	virtual void Function2() 
	{
		cout << "This is Base Function2" << endl;
	}
};

class Derive:public Base{
	public:
	void Function() 
	{
		cout << "This is Derive Function" << endl;
	}
	void Function1() 
	{
		cout << "This is Derive Function1" << endl;
	}	
};



int main()
{
	Derive der;
	Base *bas = (Base *)(&der);
	der.Function();
	der.Function1();
	der.Function2();
	
	cout << endl;
	
	bas->Function();
	bas->Function1();
	bas->Function2();
	
	return 0;
}


输出结果:

/*
This is Derive Function
This is Derive Function1
This is Base Function2

This is Base Function
This is Derive Function1
This is Base Function2
*/

对于每一个有虚函数的类来说,它都有一个属于自己的虚表(vtable),而且每一个类只有唯一的一个vtable

这个虚表,实质上来说是一个函数指针数组,该数组记录了所有虚函数的函数指针。

在上面的代码中,我们定义了一个Derive类的对象,然后用一个Base类的指针指向它,为什么Function1还是Derive呢?

因为这个对象的虚表是固定的,虚表里所指向的Function1已经被重装,当Derive类型的指针被强制转换成Base类型的时候,因为虚表的唯一性,所以,虚表里的两个函数指针所指向的函数依然是,已经重载过的Function1和没有被重载过的Function2,而Function由于不是虚函数,所以自然输出的是Base Function 和 指针类型保持一致.

嗯,暂时理解的就是这么多,等以后深入了之后再补充。



that’s all ...



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值