C++智能指针剖析

本文介绍了C++中智能指针的作用,详细讲解了std::auto_ptr、boost::scoped_ptr、boost::shared_ptr和boost::weak_ptr四种智能指针的特性和使用场景,强调了std::auto_ptr的弊端及避免循环引用的重要性。
摘要由CSDN通过智能技术生成

为什么要有?什么是智能指针?

由于 C++ 语言没有自动内存回收机制,程序员每次 new 出来的内存都要手动 delete。程序员忘记 delete,流程太复杂,最终导致没有 delete,异常导致程序过早退出,没有执行 delete 的情况并不罕见。

为了方便内存回收,便有了智能指针。

常见的智能指针

0.汇总

对于编译器来说,智能指针实际上是一个栈对象,并非指针类型,在栈对象生命期即将结束时,智能指针通过析构函数释放有它管理的堆内存。所有智能指针都重载了“operator->”操作符,直接返回对象的引用,用以操作对象。访问智能指针原来的方法则使用“.”操作符。

访问智能指针包含的裸指针则可以用 get() 函数。由于智能指针是一个对象,所以if (my_smart_object)永远为真,要判断智能指针的裸指针是否为空,需要这样判断:if (my_smart_object.get())。

智能指针包含了 reset() 方法,如果不传递参数(或者传递 NULL),则智能指针会释放当前管理的内存。如果传递一个对象,则智能指针会释放当前对象,来管理新传入的对象。

1.std::auto_ptr

注意:这个属于STL库。c++98提供的解决方案,C+11已将将其摒弃。
侯捷–STL原码剖析一书模拟auto_ptr
这里写图片描述

我们看到重载=的时候,if(当前对象不等于传过来的对象),则释放当前对象并用来管理新传入的对象。

总结:std::auto_ptr 可用来管理单个对象的对内存,但是,请注意如下几点:
(1) 尽量不要使用“operator=”。如果使用了,请不要再使用先前对象。
(2) 记住 release() 函数不会释放对象,仅仅归还所有权。
(3) std::auto_ptr 最好不要当成参数传递。
(4) 由于 std::auto_ptr 的“operator=”问题,有其管理的对象不能放入 std::vector 等容器中。

所以,auto_ptr有很大的弊端,使用它的=时候很容易产生程序崩溃。
所以,不要使用auto_ptr。

2.boost::scoped_ptr

注意:这是属于boost库的。定义在 names

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在引用中,给出了一个程序的代码片段,这段代码涉及到了内存方面的问题。在这段代码中,函数`div()`用于进行两个整数的除法运算,如果除数为0,则会抛出`invalid_argument`异常。在`Func()`函数中,首先通过`new`关键字分别创建了两个`int`类型的指针变量`p1`和`p2`,然后调用了`div()`函数进行除法运算,并打印结果。最后,通过`delete`关键字释放了指针变量所指向的内存空间。 现在我们来分析一下这段程序中可能存在的内存方面的问题: 1. 如果在创建`p1`的语句后发生异常,那么`p1`指向的内存空间将无法被正确释放,造成内存泄漏。 2. 如果在创建`p2`的语句后发生异常,同样会导致`p2`指向的内存空间无法被正确释放,造成内存泄漏。 3. 如果在调用`div()`函数时发生异常,那么由于`p1`和`p2`指向的内存空间没有被正确释放,同样会造成内存泄漏。 为了解决这些内存问题,可以使用智能指针来管理动态分配的内存。智能指针可以自动管理内存的释放,避免内存泄漏的问题。在C++中,可以使用`std::shared_ptr`来管理动态分配的内存。它会在没有引用指向这块内存时自动释放它。 现在我们来回答相关问题: 相关问题: 1. 如果在创建`p1`的语句后发生异常,该如何处理? 在创建`p1`的语句后,可以将其包装在一个`std::shared_ptr`中,这样即使发生异常,智能指针也会自动释放其所指向的内存空间。 2. 如果在创建`p2`的语句后发生异常,该如何处理? 同样地,可以将`p2`包装在一个`std::shared_ptr`中,这样即使发生异常,智能指针也会自动释放其所指向的内存空间。 3. 如果在调用`div()`函数时发生异常,该如何处理? 可以使用`std::shared_ptr`来管理`p1`和`p2`,这样即使在调用`div()`函数时发生异常,智能指针也会自动释放`p1`和`p2`所指向的内存空间。 4. 如果多个线程同时进行拷贝操作,会出现什么问题? 在引用中,如果多个线程同时进行拷贝操作,可能会出现数据不一致的问题。这是因为在多线程环境下,共享指针的引用计数可能会出现竞争条件,导致引用计数不正确,从而无法正确地管理内存。 5. 如何使用智能指针来管理使用`new[]`创建的对象? 在引用中,如果使用`new[]`创建了对象,可以使用`std::shared_ptr`来管理这些对象。需要注意的是,`std::shared_ptr`默认使用`delete`来释放内存,而不是`delete[]`。所以,需要自定义删除器来使用`delete[]`来释放数组对象。 以上是关于C++智能指针面试题的回答。如果您还有其他
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值