智能指针SharedPtr实现

实现

下面是我参考boost写的一个实现,与boost不同的是boost 并没有限制Shared_ptr不能在堆上申请,我这里做了一个限制。

#ifndef SMART_POINTER_SHARED_PTR 
#define SMART_POINTER_SHARED_PTR

template<class T>
void checked_delete(T* del) 
{
  typedef char must_be_complete[(sizeof(T)? 1 : -1)];
  (void)sizeof(must_be_complete);
  delete del;
}

template<class T>
class SharedPtr;

template<class T>
class SharedCount {
  friend class SharedPtr<T>;
  protected:
    
    SharedCount()
      :count_(NULL),
       data_(NULL)
    {
    }
   
    SharedCount(T* data)
    {
      try 
      { 
        count_ = new int(1);
        data_ = data;
      }
      catch(...) 
      {
        checked_delete(data);
        throw;
      }
    }
  
    SharedCount(const SharedCount& tmp)
      :count_(tmp.count_) 
    {
      if(count_) { 
        __sync_fetch_and_add(count_,1);
        data_ = tmp.data_;
      }
    }

    Sh
在C++中,智能指针类型之间的转换可以通过以下几种方式实现: 1. 隐式转换:如果两个智能指针类型具有相同的底层指针类型,可以直接进行隐式转换。例如,可以将`shared_ptr`隐式转换为`unique_ptr`。 ```cpp std::shared_ptr<int> sharedPtr = std::make_shared<int>(10); std::unique_ptr<int> uniquePtr = sharedPtr; // 隐式转换 ``` 2. 显式转换:可以使用`static_pointer_cast`、`dynamic_pointer_cast`和`const_pointer_cast`等函数进行显式类型转换。 - `static_pointer_cast`用于在两个相关类型之间进行转换,不会进行运行时类型检查。 - `dynamic_pointer_cast`用于在两个相关类型之间进行转换,并进行运行时类型检查。如果转换失败,返回空指针。 - `const_pointer_cast`用于在智能指针之间进行const或volatile修饰符的转换。 ```cpp std::shared_ptr<Base> sharedPtr = std::make_shared<Derived>(); std::shared_ptr<Derived> derivedPtr = std::dynamic_pointer_cast<Derived>(sharedPtr); // 显式转换 ``` 3. 使用`get`函数智能指针的`get`函数可以获取底层的原始指针,从而进行类型转换。但请注意,这种方式不会管理资源的生命周期,需要自行确保资源的释放。 ```cpp std::shared_ptr<Base> sharedPtr = std::make_shared<Derived>(); Derived* derivedPtr = static_cast<Derived*>(sharedPtr.get()); // 使用get函数进行类型转换 ``` 需要注意的是,在进行智能指针类型转换时,请确保转换的正确性,以避免潜在的内存安全问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值