C++的智能指针

很久之前,我们说到了new和delete关键字。

new在堆上分配内存,需要delete来删除内存、释放内存,因为它不会自动释放内存。

智能指针是实现过程自动化的一种方式,即当我们调用new时,我们不需要调用delete关键字。

在很多情况下我们甚至不需要调用new。

智能指针实际上是一个原始指针的包装,当我们创建一个智能指针,它会调用new并为我们分配内存,然后基于我们使用的智能指针,这些内存会在某一时刻自动释放。

我们首先来了解一下unique_ptr

unique_ptr是作用域指针,是超出作用域时他会被销毁,然后调用delete

我们不可以复制一个unique_ptr,因为如果复制一个unique_ptr,那么我们就有两个指针指向了同一块内存地址。如果其中一个die了,那么它就会释放这段内存,也就是说,指向同一块内存的第二个unique_ptr指向了被释放的内存,所以我们不可以复制unique_ptr。

注意:要访问智能指针,我们需要memory头文件

#include<iostream>
#include<string>
#include<memory>


class Entity
{
public:
    Entity()  //构造函数
    {
        std::cout<<"Create Entity!"<<std::endl;
    }
    ~Entity()  //析构函数
    {
        std::cout<<"Destory Entity!"<<std::endl;
    }
    void Print(){}
};

int main()
{
    {
        // std::unique_ptr<Entity> entity(new Entity()); 
        //entity=new Entity是不可以的,因为unique_ptr需要显式地调用
        //尖括号的Entity是unique_ptr的模版,entity是unique_ptr的名字
        std::unique_ptr<Entity> entity = std::make_unique<Entity>();
        //推荐,因为如果构造函数抛出异常,这种方式会稍微安全一些,因为我们不会得到一个没有引用的悬空指针从而造成内存泄露
        entity->Print();//我们可以调用想要的任何方法 
    }
    std::cin.get();
}

共享指针shared_ptr的工作方式是通过引用计数,引用计数基本上是一种方法,可以跟踪我们的指针有多少个引用,一旦引用计数达到0,它就被删除了

shared_ptr需要分配一块内存,叫做控制块,用来存储引用计数

弱指针weak_ptr

相关推荐
童先生14 分钟前
Go 项目中实现类似 Java Shiro 的权限控制中间件?
开发语言·go
lulu_gh_yu15 分钟前
数据结构之排序补充
c语言·开发语言·数据结构·c++·学习·算法·排序算法
Re.不晚39 分钟前
Java入门15——抽象类
java·开发语言·学习·算法·intellij-idea
老秦包你会41 分钟前
Qt第三课 ----------容器类控件
开发语言·qt
凤枭香44 分钟前
Python OpenCV 傅里叶变换
开发语言·图像处理·python·opencv
ULTRA??1 小时前
C加加中的结构化绑定(解包,折叠展开)
开发语言·c++
远望清一色1 小时前
基于MATLAB的实现垃圾分类Matlab源码
开发语言·matlab
confiself1 小时前
大模型系列——LLAMA-O1 复刻代码解读
java·开发语言
凌云行者1 小时前
OpenGL入门005——使用Shader类管理着色器
c++·cmake·opengl
XiaoLeisj1 小时前
【JavaEE初阶 — 多线程】Thread类的方法&线程生命周期
java·开发语言·java-ee