C++多态用派生类指针调用基类虚函数

多态的使用方法是当基类指针指向派生类对象时,可以直接调用派生类重写的虚函数,而不是基类的虚函数。实现方法也是老生常谈,通过每个对象中的虚函数表指针,去找属于自己类的虚函数执行。那如果用派生类指针指向基类然后调用虚函数呢?

#include<iostream>
#include<vector>
using namespace std;
class A
{
public:
	virtual void p()
	{
		cout<<"a"<<endl;
	}
};
class B:public A
{
public:
	virtual void p()
	{
		cout<<"b"<<endl;
	}
	int x;
};
int main ()
{
	A a;
	B b;
	B*p=reinterpret_cast<B*>(&a);
	p->p();
	cout<<p->x<<endl;
	cout<<&(p->x)<<' '<<p<<endl;
}

B是A的派生类,在指针赋值的时候需要加上转型动作,否则过不了编译,但是如果用派生类地址给基类指针赋值就没关系,而且这里的转型动作如果用新式转型的话,static_cast,reinterpret_cast都是可以的,但是dynamic_cast会在程序执行时退出,因为它会在执行时检测这个转型是否属于向上转型,也就是说从基类指针转向派生类指针是不被他允许的。

程序输出结果

第一行和我们想的一样,因为调用的函数是虚函数,所以通过虚函数表指针寻址,找到了属于本类的虚函数,并且执行。

第二行我们输出了基类中不存在的成员变量,输出了一个随机值。

第三行输出对象的地址和成员变量的地址,发现它们的格局和B是一样的。

总结一下,因为派生类指针可以访问的内容由指针类型决定,用它来指向基类会导致可以访问不属于基类的东西,引发安全问题,和多态的实现并没有什么关系。

猜你喜欢

转载自blog.csdn.net/qq_33113661/article/details/88709975