从unique_ptr赋值到shared_ptr引起的指针悬空bug

c++相对于其他oop语言最强大也最麻烦的莫过于必须自己处理垃圾回收。内存的随意分配,满篇的各种指针不注意就会出现野指针(悬空指针)或者内存泄露。我最近在维护一个所里的服务器项目时就吃了这个苦头。
当启动服务器后运行一段时间就会崩溃,仔细看输出窗口发现是堆栈被破坏,vs也很友好的提醒exe或者所加载的dll中存在bug(完全是废话嘛)。好的,断定是内存问题,那么应该有三种可能:1、内存越界,2、访问野指针3、多线程下访问非线程安全指针(多线程访问静态全局区域或者heap上的内存时)。确定问题后一一排查,却没发现头绪,因为每次崩溃的地方不一致,那么可以断定必然是出现了野指针,但是由于服务器程序开了20个线程,于是硬着头皮开始跟踪程序,几经周折终于找出问题所在。请看下面一段代码:

``unique_ptr<InternalMessage> uptrMessage;
  shared_ptr<InternalMessage> sptrMessage(uptrMessage.get())

这段代码可能你一看就知道问题所在,uptrMessage在析构时会释放指针所指内存,此时sptrMessage所指指针就成了悬空指针!如果继续使用sptrMessage不崩溃才怪,如果指向操作系统所占内存区域或者其他受保护区域还可能引发致命错误(档然操作系统都做了保护)。所以用智能指针时不要以为就万事大吉了,还是要小心谨慎!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值