智能指针结合多态可安全管理对象生命周期,需基类定义虚析构函数。使用std::unique_ptr<Animal>或std::shared_ptr<Animal>指向派生类对象时,虚函数机制正常工作,speak()调用对应派生类版本。析构时通过虚析构函数确保派生类资源正确释放。示例中vector<unique_ptr<Animal>>存储Dog和Cat对象,遍历时自动调用各自speak(),输出Woof!和Meow!。容器销毁时智能指针自动清理对象,无需手动delete,适用于插件系统等场景。

智能指针与多态的结合是现代C++中资源管理和对象生命周期控制的核心技术之一。通过将智能指针(如
std::unique_ptr
std::shared_ptr
当使用基类指针指向派生类对象时,虚函数机制确保调用的是派生类的重写版本。智能指针作为“指针的封装”,同样支持这一行为,只要其指向的对象具有虚函数接口。
关键在于:基类必须定义虚析构函数,否则通过基类指针删除派生类对象会导致未定义行为。
virtual
unique_ptr<Base>
shared_ptr<Base>
示例:
#include <memory>
#include <iostream>
struct Animal {
    virtual ~Animal() = default;
    virtual void speak() const { std::cout << "Animal sound\n"; }
};
struct Dog : Animal {
    void speak() const override { std::cout << "Woof!\n"; }
};
struct Cat : Animal {
    void speak() const override { std::cout << "Meow!\n"; }
};
int main() {
    std::vector<std::unique_ptr<Animal>> animals;
    animals.push_back(std::make_unique<Dog>());
    animals.push_back(std::make_unique<Cat>());
    for (const auto& animal : animals) {
        animal->speak();  // 正确调用派生类函数
    }
    return 0;
}
输出:
Woof! Meow!
智能指针在析构其所管理的对象时,会自动调用对象的析构函数。由于基类析构函数是虚函数,实际调用的是派生类的析构函数,从而实现完整的资源清理。
这一点在
unique_ptr
shared_ptr
unique_ptr
shared_ptr
注意:如果基类没有虚析构函数,即使使用智能指针,也可能导致派生类部分未被销毁。
将多态对象存入容器时,使用智能指针(尤其是
unique_ptr
常见模式是
std::vector<std::unique_ptr<Base>>
delete
这种模式广泛应用于事件处理器、插件系统、图形对象管理等场景。
基本上就这些。只要基类有虚析构函数,智能指针就能安全地管理多态对象,虚函数调用行为与裸指针完全一致,但更安全、更清晰。
以上就是智能指针与多态如何配合 虚函数在智能指针中的表现的详细内容,更多请关注php中文网其它相关文章!
                        
                        每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
                Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号