草庐IT

Unique_ptr

全部标签

C++ 对象池,将项目作为智能指针提供,在删除时返回到池中

我对c++-ideas很感兴趣,但遇到了这个问题。我想要LIFO管理资源池的类。当请求资源时(通过acquire()),它将对象作为unique_ptr返回这在删除时会导致资源返回到池中。单元测试是://Createthepool,thatholds(forsimplicity,intobjects)SharedPoolpool;TS_ASSERT(pool.empty());//Addanobjecttothepool,whichisnow,nolongeremptypool.add(std::unique_ptr(newint(42)));TS_ASSERT(!pool.empty

c++ - 不同风格的 shared_ptr 之间的差异

boost::shared_ptr之间有什么区别吗?,std::tr1::shared_ptr和即将到来的(在C++0x中)std::shared_ptr?从一个移植到另一个是否会有任何开销或者它们基本相同? 最佳答案 根据Boost网站,boost::shared_ptr......conformstotheTR1specification,withtheonlyexceptionthatitresidesinnamespaceboostinsteadofstd::tr1.根据维基百科C++0x页面TheTR1implementa

c++ - 不同风格的 shared_ptr 之间的差异

boost::shared_ptr之间有什么区别吗?,std::tr1::shared_ptr和即将到来的(在C++0x中)std::shared_ptr?从一个移植到另一个是否会有任何开销或者它们基本相同? 最佳答案 根据Boost网站,boost::shared_ptr......conformstotheTR1specification,withtheonlyexceptionthatitresidesinnamespaceboostinsteadofstd::tr1.根据维基百科C++0x页面TheTR1implementa

c++ - 为什么 shared_ptr 引用计数对象也需要跟踪指向该对象的 weak_ptr 上的数字?

您好,我正在阅读thisdocument和其他一些关于C++的shared_ptr的文档,他们似乎都建议除了指向分配对象的shared_ptr的数量之外,引用计数对象必须跟踪如何许多weak_ptr指针也指向该对象。我的问题是为什么?据我了解,weak_ptr是非拥有的,因此如果指向对象的shared_ptr计数达到零,则可以删除该对象。这就是为什么有时我们需要使用expired检查weak_ptr指向的对象的可用性。您能解释一下需要跟踪weak_ptr数量的原因吗?为什么我们在这里需要弱计数? 最佳答案 std::weak_ptr

c++ - 为什么 shared_ptr 引用计数对象也需要跟踪指向该对象的 weak_ptr 上的数字?

您好,我正在阅读thisdocument和其他一些关于C++的shared_ptr的文档,他们似乎都建议除了指向分配对象的shared_ptr的数量之外,引用计数对象必须跟踪如何许多weak_ptr指针也指向该对象。我的问题是为什么?据我了解,weak_ptr是非拥有的,因此如果指向对象的shared_ptr计数达到零,则可以删除该对象。这就是为什么有时我们需要使用expired检查weak_ptr指向的对象的可用性。您能解释一下需要跟踪weak_ptr数量的原因吗?为什么我们在这里需要弱计数? 最佳答案 std::weak_ptr

c++ - make_unique 值是否初始化 char 数组

例如-#includeintmain(){constautobufSize=1024;autobuffer=std::make_unique(bufSize);}这里的缓冲区是否已经填充了'\0'字符,或者我必须手动填充它以避免垃圾值。有什么可能的方法来做到这一点,std::memset(&buffer.get(),0,bufSize)就足够了吗? 最佳答案 如果您不提供构造函数参数,则所有make_*函数都会对类型使用值初始化。由于make_unique的数组形式不带任何参数,它会将元素清零。

c++ - make_unique 值是否初始化 char 数组

例如-#includeintmain(){constautobufSize=1024;autobuffer=std::make_unique(bufSize);}这里的缓冲区是否已经填充了'\0'字符,或者我必须手动填充它以避免垃圾值。有什么可能的方法来做到这一点,std::memset(&buffer.get(),0,bufSize)就足够了吗? 最佳答案 如果您不提供构造函数参数,则所有make_*函数都会对类型使用值初始化。由于make_unique的数组形式不带任何参数,它会将元素清零。

c++ - 我应该使用 boost::ptr_vector<T> 还是 vector<boost::shared_ptr<T>>?

我需要一个指针容器。你会推荐boost::ptr_vector或std::vector>?(或者别的什么?)如果感兴趣的话,我的实际数据结构相对复杂(见here)并且目前存储对象,而不是指针,但我想改变它(使用指针容器),以摆脱不必要的复制:typedefstd::multimap>VecElem;std::vectorvec; 最佳答案 谁拥有对象?如果容器拥有对象(意味着对象的生命周期不应超过容器),请使用ptr_vector。否则,使用shared_ptr的vector。标准库容器(例如std::vector或std::lis

c++ - 我应该使用 boost::ptr_vector<T> 还是 vector<boost::shared_ptr<T>>?

我需要一个指针容器。你会推荐boost::ptr_vector或std::vector>?(或者别的什么?)如果感兴趣的话,我的实际数据结构相对复杂(见here)并且目前存储对象,而不是指针,但我想改变它(使用指针容器),以摆脱不必要的复制:typedefstd::multimap>VecElem;std::vectorvec; 最佳答案 谁拥有对象?如果容器拥有对象(意味着对象的生命周期不应超过容器),请使用ptr_vector。否则,使用shared_ptr的vector。标准库容器(例如std::vector或std::lis

c++ - 在销毁期间使用 std::shared_ptr 的 Segfault 可能是由于堆栈上的函数调用过多

以下代码编译运行良好:#includestructMyTree{std::shared_ptrleft;std::shared_ptrright;intval;MyTree(std::shared_ptrleft_,std::shared_ptrright_,intval_):left(left_),right(right_),val(val_){};};intmain(){std::shared_ptrt(newMyTree(std::shared_ptr(),std::shared_ptr(),0));for(inti=0;i但是,当for循环从10000更改为100000时,我收