关于C++智能指针

普通指针到智能指针的转换
int* iPtr = new int(42);
shared_ptr<int> p(iPtr);


智能指针到普通指针的转换
int* pI = p.get();




注意的地方: 那就是不要将智能指针与普通指针混用。如果项目允许,坚持使用智能指针,避免原生指针。

智能指针与普通指针需要特别特别特别的小心翼翼,比如以下的情况。
1. 普通指针到智能指针的问题
void f(shared_ptr<int> ptr) //增加引用计数
{
   // do something...
} //销毁ptr,减少引用计数



我们有如下的代码:
int* iPtr = new int(42);
f(shared_ptr<int>(iPtr));
int value = *iPtr; // Error! iPtr指针指向的内容已经被释放



因为在这儿,你将普通指针赋予给了一个临时的智能指针,当调用f函数完毕后,此临时智能指针的生命周期结束,然后减少引用计数,归为0,于是,内存释放!

而这儿的更改方法是一直使用智能指针:
auto p = make_shared<int>(42); // 初始化的引用计数为1
f(p); // 拷贝后增加为2,销毁ptr减少1,然后变为1
int value = *p; //引用计数为1




2. 智能指针到普通指针的问题
auto p = make_shared<int>(42);
int* iPtr = p.get();
{
   shared_ptr<int>(iPtr);
}

int value = *p; // Error! 内存已经被释放


p与iPtr指向了相同的内存,然而通过get方法后,将内存管理权转移给了普通指针。iPtr传递给里面程序块的临时智能指针后,引用计数为1,随后出了作用域,减少为0,释放内存。


额外的注意点:转换
在C++11中,极力推崇完全替代原生指针。而这里面,原生指针使用到了static_cast,dynamic_cast, const_cast的操作,需要用static_pointer_cast, dynamic_pointer_cast, const_pointer_cast对应操作,而并非使用原来的dynamic_cast等。
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值