c++11智能指针(三):shared_ptr和指针

本节对比一下C++11智能指针的实现shared_ptr和普通的指针
从以下几个方面比较:

++,--和[]操作符

相比于原始指针,shared_ptr只提供这些运算符:
1) ->, *
2) 比较运算符
但是,shared_ptr不提供
1) 指针运算比如+,-,++,--
2) Operator []

例子:

#include <iostream>
#include <memory>
 
struct Sample {
  void dummyFunction() {
    std::cout << "dummyFunction" << std::endl;
  }
};
 
int main() {
  std::shared_ptr<Sample> ptr = std::make_shared<Sample>();
 
  (*ptr).dummyFunction();    //正确
 
  ptr->dummyFunction();      //正确
 
  //ptr[0]->dummyFunction(); //错误
  //ptr++;                   //错误
  //ptr--;                   //错误
 
  std::shared_ptr<Sample> ptr2(ptr);
 
  if (ptr == ptr2)
    std::cout << "ptr and ptr2 are equal" << std::endl;
 
  return 0;
}
输出:
dummyFunction
dummyFunction
ptr and ptr2 are equal


NULL检测

如果创建一个shared_ptr对象而不分配任何值时,它默认为空值。
在没有声明的情况下,原始指针将包含垃圾值,我们无法验证它是否包含垃圾。
使用shared_ptr,可以这样检查空值:
std::ahred_ptr<Sample> ptr3;
if(!ptr3)
    std::cout<<"Yes, ptr3 is empty"<<std::endl;
if(ptr3 == NULL)
    std::cout<<"ptr3 is empty"<<std::endl;
if(ptr3 == nullptr)
    std::cout<<"ptr3 is empty"<<std::endl;


我们还可以这样访问shared_ptr的内部原始指针:
std::shared_ptr<Sample> ptr = std::make_shared<Sample>();
Sample * raw = ptr.get();
理想情况下,我们不应该使用这个,因为如果我们误删了这个指针,会导致问题。在这种情况下,当shared_ptr对象将超出范围,那么它将尝试删除已经删除的内存,这会导致程序崩溃。下一节将会仔细讨论这个问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值