Technical Report 1 是一份规范,描述加入C++标准程序的诸多新技能,以新的class templates 和 function templates 形式体现,针对的题目有哈希表,基于引用计数的智能指针,正则表达式等。大多数TR1机能是以Boost的工作为基础的。TR组件位于std::tr1命名空间中。
tr1::shared_ptr 的使用和boost::shared_ptr 类似,都是基于引用计数值的智能指针。#include <memory> 以使用shared_ptr。
1. 在可能会引起循环引用的地方,使用weak_ptr。
#include <iostream>
#include <memory>
class A;
class B;
typedef std::tr1::shared_ptr<A> APtr;
typedef std::tr1::shared_ptr<B> BPtr;
class A
{
public:
BPtr b;
~A()
{
std::cout << "A released." << std::endl;
}
};
class B
{
public:
APtr a;
~B()
{
std::cout << "B released." << std::endl;
}
};
int _tmain(int argc, _TCHAR* argv[])
{
APtr objA(new A());
BPtr objB(new B());
objA->b = objB; //1
objB->a = objA; //2
return 0;
}
执行完什么也没有输出,说明 A 和 B 都没有执行析构函数,资源泄漏了。指针objA 的生命周期结束时,对其的引用计数为1,即objB手中的引用,所以对象objA不会释放。ob

本文介绍了C++ Technical Report 1 (TR1) 库中的智能指针,特别是`tr1::shared_ptr`和`tr1::weak_ptr`。`shared_ptr`用于引用计数管理,而在解决循环引用问题时,`weak_ptr`发挥了关键作用。通过`enable_shared_from_this`基类,可以从对象自身创建`shared_ptr`,但需要注意在构造函数中调用`shared_from_this()`会导致失败。
最低0.47元/天 解锁文章
1089

被折叠的 条评论
为什么被折叠?



