多态性通过虚函数和动态绑定实现,允许基类指针在运行时调用派生类函数。虚函数使用virtual关键字声明,派生类可重写其行为。示例中Animal类定义虚函数speak(),Dog和Cat类分别重写该函数输出不同内容。动态绑定依赖虚函数表(vtable)和虚函数指针(vptr),每个含虚函数的类维护一个vtable存储函数指针,对象通过vptr指向对应vtable。当通过基类指针调用虚函数时,程序根据实际对象类型查找vtable并调用相应函数,实现运行时多态。如Animal* ptr指向Dog对象时调用Dog::speak(),指向Cat对象时调用Cat::speak()。纯虚函数以virtual void func() = 0;形式定义,使类成为抽象类,不能实例化,只能被继承,强制派生类实现接口。这增强了多态设计能力,适用于构建可扩展架构。虚函数是C++运行时多态核心机制,支持灵活、模块化程序设计。

在C++中,多态性主要通过虚函数和动态绑定机制来实现。它允许基类的指针或引用在运行时调用派生类的函数,从而实现“一个接口,多种实现”的设计思想。
虚函数的定义与作用
虚函数是在基类中使用virtual关键字声明的成员函数,它为派生类提供了一个可重写的接口。
当派生类重写该函数后,通过基类指针或引用调用该函数时,会根据实际对象的类型决定调用哪个版本。
示例:
立即学习“C++免费学习笔记(深入)”;
class Animal { class Dog : public Animal { class Cat : public Animal {
public:
virtual void speak() {
cout
}
};
public:
void speak() override {
cout
}
};
public:
void speak() override {
cout
}
};
动态绑定如何工作
动态绑定是指函数调用在运行时才确定具体调用哪个函数,而不是在编译时决定。这依赖于虚函数表(vtable)和虚函数指针(vptr)机制。
- 每个含有虚函数的类都有一个虚函数表,其中存储了指向各个虚函数的指针
- 每个对象包含一个隐式的虚函数指针,指向其类的虚函数表
- 当通过基类指针调用虚函数时,程序通过该指针找到实际对象的vtable,再调用对应函数
这意味着即使指针类型是基类,只要指向的是派生类对象,就会调用派生类的函数实现。
示例调用:
Animal* ptr; ptr = &dog; ptr = &cat;
Dog dog;
Cat cat;
ptr->speak(); // 输出:Dog barks
ptr->speak(); // 输出:Cat meows
纯虚函数与抽象类
如果希望基类中的虚函数没有实现,强制派生类提供自己的版本,可以使用纯虚函数。
语法:virtual void func() = 0;
包含纯虚函数的类称为抽象类,不能实例化对象,只能作为接口被继承。
这进一步增强了多态的设计能力,适合构建稳定接口和可扩展架构。
基本上就这些。虚函数是C++实现运行时多态的核心,动态绑定让程序更灵活,支持扩展和模块化设计。不复杂但容易忽略细节。










