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

相关推荐
jllllyuz8 分钟前
matlab使用B样条进行曲线曲面拟合
开发语言·matlab
农夫山泉2号22 分钟前
【c++】——c++编译的so中函数有额外的字符
java·服务器·c++
ku_code_ku35 分钟前
python bert_score使用本地模型的方法
开发语言·python·bert
小马哥编程41 分钟前
【软考架构】滑动窗口限流算法的原理是什么?
java·开发语言·架构
仰泳的熊猫44 分钟前
1077 Kuchiguse
数据结构·c++·算法·pat考试
云栖梦泽1 小时前
鸿蒙数据持久化实战:构建本地存储与云同步系统
开发语言·鸿蒙系统
wjs20241 小时前
《Ionic 侧栏菜单》
开发语言
祁思妙想1 小时前
linux常用命令
开发语言·python
IMPYLH1 小时前
Lua 的 IO (输入/输出)模块
开发语言·笔记·后端·lua
普通网友1 小时前
Objective-C 类的方法重载与重写:区别与正确使用场景
开发语言·ios·objective-c