C++ std::make_unique和std::make_shared用法小结

 更新时间:2023年11月15日 09:32:04   作者:千山万水人海中666  
本文主要介绍了C++ std::make_unique和std::make_shared用法,使用std::make_unique和std::make_shared能够简化动态分配内存和构造对象的过程,提高代码的安全性和可读性,感兴趣的可以了解一下

std::make_unique 和 std::make_shared 是 C++11 引入的两个辅助函数,用于创建动态分配的智能指针 std::unique_ptr 和 std::shared_ptr,分别帮助避免了显式使用 new 和 delete,从而提高代码的安全性和可读性。

std::make_unique:

#include <memory>

int main() {
    // 使用 std::make_unique 创建动态分配的对象
    std::unique_ptr<int> uniquePtr = std::make_unique<int>(42);

    // 使用动态分配的对象
    std::cout << *uniquePtr << std::endl;

    // 不需要手动释放内存,unique_ptr 会在其生命周期结束时自动释放
    return 0;
}

std::make_unique 接受可变数量的参数并返回一个 std::unique_ptr,它在分配内存和构造对象时是一个原子操作。使用 std::make_unique 的优点是可以避免内存泄漏,因为它将分配和构造操作合并在一起,如果构造函数抛出异常,std::make_unique 会确保释放已分配的内存。

std::make_shared:

#include <memory>

int main() {
    // 使用 std::make_shared 创建动态分配的对象
    std::shared_ptr<int> sharedPtr = std::make_shared<int>(42);

    // 使用动态分配的对象
    std::cout << *sharedPtr << std::endl;

    // 不需要手动释放内存,shared_ptr 会在最后一个引用消失时自动释放
    return 0;
}

std::make_shared 与 std::make_unique 类似,但它还有一个额外的优势,即在分配内存时将引用计数分配在同一块内存中,从而减少了内存开销。std::make_shared 通常是推荐使用的方式,因为它可以提高性能,并在一些情况下减少内存使用。

总的来说,使用 std::make_unique 和 std::make_shared 能够简化动态分配内存和构造对象的过程,提高代码的安全性和可读性。

到此这篇关于C++ std::make_unique和std::make_shared用法小结的文章就介绍到这了,更多相关C++ std::make_unique和std::make_shared内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 深入解析C++中的mutable关键字

    深入解析C++中的mutable关键字

    在C++中,mutable也是为了突破const的限制而设置的。被mutable修饰的变量,将永远处于可变的状态,即使在一个const函数中
    2013-10-10
  • C语言实现分治法实例

    C语言实现分治法实例

    这篇文章主要为大家详细介绍了C语言实现分治法的实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-08-08
  • C语言植物大战数据结构二叉树堆

    C语言植物大战数据结构二叉树堆

    这篇文章主要为大家介绍了C语言植物大战数据结构二叉树堆的图文示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-05
  • uboot添加自定义命令的实现步骤

    uboot添加自定义命令的实现步骤

    uboot 属于bootloader的一种,是用来引导启动内核的,它的最终目的就是从flash中读出内核,放到内存中,启动内核,这篇文章主要介绍了uboot添加自定义命令的实现步骤,需要的朋友可以参考下
    2022-11-11
  • C语言怎么获得进程的PE文件信息

    C语言怎么获得进程的PE文件信息

    这篇文章主要介绍了C语言怎么获得进程的PE文件信息的相关代码,需要的朋友可以参考下
    2016-01-01
  • C语言详解冒泡排序实现

    C语言详解冒泡排序实现

    冒泡排序是一种简单的排序算法,它也是一种稳定排序算法。其实现原理是重复扫描待排序序列,并比较每一对相邻的元素,当该对元素顺序不正确时进行交换。一直重复这个过程,直到没有任何两个相邻元素可以交换,就表明完成了排序
    2022-04-04
  • C++的new和delete使用示例详解

    C++的new和delete使用示例详解

    这篇文章主要为大家介绍了C++的new和delete使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • C语言项目小学生数学考试系统参考

    C语言项目小学生数学考试系统参考

    今天小编就为大家分享一篇关于C语言项目小学生数学考试系统参考,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-02-02
  • socket编程的详细讲解

    socket编程的详细讲解

    本文详细讲解了socket编程,它是网络中经常使用的一门技术,该文章通过大量的代码来解释,大家可以参考参考
    2021-08-08
  • C语言数据结构 链表与归并排序实例详解

    C语言数据结构 链表与归并排序实例详解

    这篇文章主要介绍了C语言数据结构 链表与归并排序实例详解的相关资料,需要的朋友可以参考下
    2017-01-01

最新评论