C++虚函数

今天,我来讲一种在C++编程中实现多态的机制,叫做虚函数。对于多态来说,实际上就是用父类型的指针指向子类的实例,然后通过父类的指针调用子类的成员函数,这种技术使得父类型的指针有多种形态,这是一种常见的泛型技术,除虚函数外,还有模板技术,RTTI技术也属于泛型技术。

 

为了清楚地理解多态,先看下面这段代码。

 

#include <bits/stdc++.h>

using namespace std;

class Base{
public:
	void Print()
	{
		cout << "This is Base!" << endl;
	}
};

class Driver : Base{
public:
	void Print()
	{
		cout << "This is Driver!" << endl;
	}
};

int main()
{
	Base A;
	Driver B;
	A.Print();
	B.Print();
	return 0;
}

 

这段代码运行结果如下

 

 

 

这个结果是我们可以预料到的,如果子类继承了父类的方法,并且子类中会覆盖父类中名字相同的方法。那么这样就真正做到了多态了吗? 答案是否定的。从多态来说,是指用一切基类的指针来指向子类的实例,那么稍修改,如下

 

#include <bits/stdc++.h>

using namespace std;

class Base{
public:
	void Print()
	{
		cout << "This is Base!" << endl;
	}
};

class Driver : public Base{
public:
	void Print()
	{
		cout << "This is Driver!" << endl;
	}
};

int main()
{
	Base A;
	Driver B;
	Base *ptr1 = &A;
	Base *ptr2 = &B;
	ptr1->Print();
	ptr2->Print();
	return 0;
}


这样修改之后结果如下

 

 

 

ptr2明明是指向Driver的对象,调用的却是class A的函数,这明显不是我们期望的目标。

 

#include <bits/stdc++.h>

using namespace std;

class Base{
public:
	virtual void Print()   //在原来的基础上加virtual,使Print()成为虚函数
	{
		cout << "This is Base!" << endl;
	}
};

class Driver : public Base{
public:
	void Print()           //子类在继承父类时,不再需要加virtual了,此时重写Print()方法后就已经是虚函数了
	{
		cout << "This is Driver!" << endl;
	}
};

int main()
{
	Base A;
	Driver B;
	Base *ptr1 = &A;
	Base *ptr2 = &B;
	ptr1->Print();
	ptr2->Print();
	return 0;
}


声明为虚函数后,就得到了如下运行结果

 

 

 

那么虚函数是如何做到这一点的呢 ?现在我们就来剖析。

 

如果一个类中有虚函数,那么编译器就会给这个类分配一个指针vptr,并且创建一张表,这个vptr指针指向那张表,这张表叫做虚表。虚表的作用就是保存自己类中虚函数的地址。我们可以把虚表看成一个数组,这个数组的每个元素存放的是虚函数的地址。

 

关于虚表资料请参考:http://blog.csdn.net/haoel/article/details/1948051/

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值