我的記錄:
1.指定了釋放器,就不會去直接調用解構函式。因為釋放器就一個。不指定的話解構函式就是釋放器.
2.STL智能指標對內建內型的支援不如class:比如shared_ptr<char> s(new char[10]); memset(s, 0x00, 10);//error! 只能memset(s.get(), ....了。
3. auto_ptr不能指定釋放器.
#include "iostream"#include <tr1/memory>using namespace std;using std::tr1::shared_ptr;using std::auto_ptr;class C{public:C(){ cout<<"C()"<<endl; buf = new char[10];}~C(){ cout<<"~C()"<<endl; if(buf){cout<<"~C() delete []buf."<<endl; delete [] buf;}}static void MyRelease(C * pC){cout<<"MyRelease()"<<endl;cout<<"MyRelease() delete [] buf."<<endl;delete [] pC->buf;pC->buf = NULL;cout<<"MyRelease() delete C:";delete pC;//call ~C().} private:char * buf;};int main(){cout<<"std::tr1::shared_ptr<C>:"<<endl;{C * a = new C;shared_ptr<C> shareC(a, C::MyRelease); }cout<<"<- shared_ptr test ended.\n"<<endl;cout<<"std::tr1::shared_ptr<C> copy test"<<endl;{shared_ptr<C> shareC(new C, C::MyRelease);shared_ptr<C> shareC2 = shareC;}cout<<"<- shared_ptr copy test ended.\n"<<endl;cout<<"std::auto_ptr<C>:"<<endl;C * b = new C;auto_ptr<C> autoC(b);cout<<"return 0;"<<endl;return 0;}
$ g++ main.cpp