【C++】C++多态性解析(调用函数)

本文通过实例深入解析C++中基类与派生类的普通函数及虚函数调用机制,展示了如何利用指针实现多态性,以及普通函数与虚函数在不同情况下的行为差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

文章目录

总结

普通函数:调用基类还是派生类普通函数,主要是看定义的是基类指针还是派生类指针
虚函数:调用基类还是派生类虚函数,主要看定义的指针实际指向基类还是派生类。

例子

测试程序:

#include<iostream>
using namespace std;
class Base//抽象类
{
public:
	void fun()//普通函数,静态绑定
	{
		cout << "调用基类普通成员函数" << endl;
	}
	virtual void virFun()//虚函数,动态绑定
	{
		cout << "调用基类虚函数" << endl;
	}
	virtual void pureVirFun() = 0;//纯虚函数,接口
};

class A :public Base//基类A
{
public:
	void fun()
	{
		cout << "调用A基类普通成员函数" << endl;
	}
	virtual void virFun()
	{
		cout << "调用A基类虚函数" << endl;
	}
	virtual void pureVirFun() override
	{
		cout << "调用A基类纯虚函数" << endl;
	}
};

class B :public A//派生类B
{
public:
	void fun()
	{
		cout << "调用B派生类普通成员函数" << endl;
	}
	virtual void virFun()
	{
		cout << "调用B派生类虚函数" << endl;
	}
	virtual void pureVirFun() override
	{
		cout << "调用B派生类纯虚函数" << endl;
	}
};
运行变量:

int main() 
{
	A a;
	B b;
	A* ptr = &a;//定义指向基类A的指针
	cout << "基类A指针地址:" << ptr << endl;
	ptr->fun();
	ptr->virFun();
	ptr->pureVirFun();
	cout << endl;


	//note:虽然ptr = ptrB但是其指向的内容不一样,
	//函数运行结果也不一定一样(多态性)
	ptr = &b;//基类指针指向派生类
	cout << "基类指针指向派生类B的地址:" << ptr << endl;
	ptr->fun();
	ptr->virFun();
	ptr->pureVirFun();
	cout << endl;

	B* ptrB = &b;//指向子类的指针
	cout << "指向派生类B的指针地址:" << ptrB << endl;
	ptrB->fun();
	ptrB->virFun();
	ptrB->pureVirFun();
	cout << endl;

	B* ptrBA = (B*)&a;//基类地址,强转指向B
	cout << "基类地址,再强转指向B的指针地址:" << ptrBA << endl;
	ptrBA->fun();
	ptrBA->virFun();
	ptrBA->pureVirFun();
	cout << endl;

	system("pause");
	return 0;
}

yunxing
运行结果:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值