由仿函数引出的定制删除器

  先简单介绍一下仿函数是什么:仿函数(functor),就是使一个类的使用看上去像一个函数。其实现就是类中实现一个operator(),这个类就有了类似函数的行为,就是一个仿函数类了。

  简单定义了一下删除器需要的仿函数

#include<iostream>
#include<cstdlib>
#include<boost\shared_ptr.hpp>
using namespace std;
struct Fclose
{
   void operator()(void *ptr)
   {
      fclose((FILE*)ptr);
   cout<<"close file"<<endl;
  
   }

};
struct Free
{
   void  operator()(void *ptr)
   {
     free(ptr);
  cout<<"free"<<endl;
  
   }
};
struct Delete
{
   void operator()(void *ptr)
   {
      delete ptr;
   cout<<"delete"<<endl;
   }
};
struct DeleteArray
{
 void operator()(void *ptr)
 {
    delete[]ptr;
    cout<<"deletle array"<<endl;
 }
};

void test()
{
   boost::shared_ptr<FILE> p1(fopen("test.txt","w"),Fclose());        //像调用函数一样使用
   int *p=(int*)malloc(sizeof(int));
    boost::shared_ptr<int> p2(p,Free());
 int *p3=new int(1);
 boost::shared_ptr<int> p3_ptr(p3,Delete());
 char* p4=new char[4];
 boost::shared_ptr<char> p4_ptr(p4,DeleteArray());
}
int main()
{
   test();

  system("pause");
  return 0;
}



使用仿函数可以来定制删除器
#include<iostream>
#include<cstdlib>
#include<boost\shared_ptr.hpp>
using namespace std;
struct Fclose
{
   void operator()(void *ptr)
   {
      fclose((FILE*)ptr);
   cout<<"close file"<<endl;
  
   }

};
struct Free
{
   void  operator()(void *ptr)
   {
     free(ptr);
  cout<<"free"<<endl;
  
   }
};
struct Delete
{
   void operator()(void *ptr)
   {
      delete ptr;
   cout<<"delete"<<endl;
   }
};
struct DeleteArray
{
 void operator()(void *ptr)
 {
    delete[]ptr;
    cout<<"deletle array"<<endl;
 }
};


template<typename T,typename D=Delete>
class SharedePtr
{
public:
 SharedePtr(T* ptr)
  :_ptr(ptr),
  _pcount(new int(1)),
  _del(D())
 {}
 ~SharedePtr()
 {
    Release();
 }
 SharedePtr(SharedePtr<T,D>& sp)
 {
   _ptr=sp._ptr;
   _pcount=sp._pcount;
   ++(*_pcount);
   return *this;
 
 }
 SharedePtr<T,D>& operator=(SharedePtr<T,D> ap)
 {
    std::swap(ap._ptr,_ptr);
    std::swap(ap._pcount,_pcount);
    return *this;
 }
     T& operator*()
   {
    return *_ptr;
   }

     T* operator->()
  {
   return _ptr;
  }
  T& ues_count()
  {
    return (*_pcount);
 
  }
private:
 void Release()
 {
  if(--*_pcount==0)
  {
   _del(_ptr);
   delete _pcount;
  }
 }
 T* _ptr;
 int* _pcount;
 D _del;

};

int main()
{
  SharedePtr<FILE,Fclose> ap(fopen("test.tex","w"));
  SharedePtr<int> ap1(new int(1));
  system("pause");
  return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值