std::shared_ptr 和多态的组合使用//test ok

在 C++ 中,std::shared_ptr 和多态(通过虚函数和基类指针/引用实现)可以很好地结合使用。这种组合通常用于管理对象的生命周期,同时允许通过基类指针或引用来实现多态。

下面是一个简单的示例,演示如何使用 std::shared_ptr 来管理多态对象的生命周期:

cpp 复制代码
#include <iostream>
#include <memory>

// 基类
class Shape {
public:
    virtual void draw() const {
        std::cout << "Drawing a shape" << std::endl;
    }

    virtual ~Shape() {
        std::cout << "Destroying a shape" << std::endl;
    }
};

// 派生类
class Circle : public Shape {
public:
    void draw() const override {
        std::cout << "Drawing a circle" << std::endl;
    }

    ~Circle() override {
        std::cout << "Destroying a circle" << std::endl;
    }
};

class Square : public Shape {
public:
    void draw() const override {
        std::cout << "Drawing a square" << std::endl;
    }

    ~Square() override {
        std::cout << "Destroying a square" << std::endl;
    }
};

int main() {
    // 使用 std::shared_ptr 管理多态对象的生命周期
    std::shared_ptr<Shape> shapePtr = std::make_shared<Circle>();
    shapePtr->draw();  // 调用派生类的虚函数

    // 另一个派生类
    shapePtr = std::make_shared<Square>();
    shapePtr->draw();  // 同样调用派生类的虚函数

    // 在 main 函数结束时,std::shared_ptr 会自动销毁对象,调用相应的析构函数
    return 0;
}
/*
root@PF34VVBR:/mnt/c/Users/User/Documents/test# g++ sharedptr_duotai.cpp -o sharedptr_duotai.o
root@PF34VVBR:/mnt/c/Users/User/Documents/test# ./sharedptr_duotai.o
Drawing a circle
Destroying a circle
Destroying a shape
Drawing a square
Destroying a square
Destroying a shape
*/

在这个例子中,Shape 是一个基类,CircleSquare 是派生类。通过使用 std::shared_ptr<Shape>,我们可以在运行时指向 CircleSquare 对象,而不用担心手动释放内存。在std::shared_ptr的析构函数中,它会调用正确的析构函数,这就是智能指针的强大之处。

这种方法还可以用于容器等数据结构,让你在使用多态的同时,充分发挥智能指针的便利性。

相关推荐
bubiyoushang88817 分钟前
基于CLEAN算法的杂波抑制Matlab仿真实现
数据结构·算法·matlab
曾经的三心草31 分钟前
redis-2-数据结构内部编码-单线程-String命令
数据结构·数据库·redis
博大世界2 小时前
matlab结构体数组定义
数据结构·算法
罗湖老棍子4 小时前
强迫症冒险家的任务清单:字典序最小拓扑排序
数据结构·算法·图论·拓扑排序
数智工坊5 小时前
【操作系统-文件管理】
数据结构·数据库
芒克芒克6 小时前
数组去重进阶:一次遍历实现最多保留指定个数重复元素(O(n)时间+O(1)空间)
数据结构·算法
Fcy6487 小时前
⽤哈希表封装unordered_map和unordered_set(C++模拟实现)
数据结构·c++·散列表
一分之二~7 小时前
二叉树--层序遍历(迭代和递归)
数据结构·c++·算法·leetcode
散峰而望9 小时前
【基础算法】高精度运算深度解析与优化
数据结构·c++·算法·链表·贪心算法·推荐算法
C雨后彩虹10 小时前
中文分词模拟器
java·数据结构·算法·华为·面试