boost里的智能指针
实际开发过程中,可能会有这样的用法:
class a
{
class b
{
...
shared_ptr<a> a_ptr;
}
...
b b_;
}
shared_ptr<a> test_ptr(new a);
test_ptr->b_.a_ptr = test_ptr;
test_ptr.reset();
这个写法会造成内存泄漏, 原因是要释放 b_. a_ptr 的内存,需要b_析构,但b_的析构却需要 a本身构造.这就造成了矛盾.
另外,基类和派生类的智能指针是不同的东西,不能直接=,虽然本质上是一个东西.
要相等需要进行类型转换,方法是:
假设b继承自a;
shared_ptr<a> ptr_a(new b);
shared_ptr<b> ptr_b (ptr_a, boost::detail::dynamic_cast_tag() );
by 老洪@2011-4-1晚