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的析构函数中,它会调用正确的析构函数,这就是智能指针的强大之处。

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

相关推荐
勇闯逆流河20 分钟前
【C++】用红黑树封装map与set
java·开发语言·数据结构·c++
一只鱼^_1 小时前
第 167 场双周赛 / 第 471 场周赛
数据结构·b树·算法·leetcode·深度优先·近邻算法·迭代加深
Seeing51 小时前
数据结构----树
数据结构
Word码2 小时前
[排序算法]希尔排序
c语言·数据结构·算法·排序算法
QT 小鲜肉3 小时前
【数据结构与算法基础】05. 栈详解(C++ 实战)
开发语言·数据结构·c++·笔记·学习·算法·学习方法
靠近彗星3 小时前
3.4特殊矩阵的压缩存储
数据结构·人工智能·算法
网安INF3 小时前
Python核心数据结构与函数编程
数据结构·windows·python·网络安全
.格子衫.4 小时前
018数据结构之队列——算法备赛
数据结构·算法
浩泽学编程5 小时前
【源码深度 第1篇】LinkedList:双向链表的设计与实现
java·数据结构·后端·链表·jdk
怎么没有名字注册了啊6 小时前
求一个矩阵中的鞍点
数据结构·算法