草庐IT

c++ - Boost.Pointer 容器在 C++11/14 中被 std::unique_ptr 淘汰了吗?

是否std::unique_ptr使Boost.PointerContainer库在C++11/14中过时?在C++98/03中没有移动语义,也没有像shared_ptr这样的智能指针。与原始指针相比,具有引用计数相关的开销(对于引用计数block和互锁增量/减量)。所以像std::vector>如果与std::vector相比有开销.但是是std::vector>与std::vector一样高效(没有引用计数开销),和此外安全关于异常和自动销毁(即vector>析构函数将自动调用析构函数对于指针存储在T中的vector项)?如果是这样,Boost.PointerContainer在C

c++ - 对使用 unique_ptr 和自定义删除器感到困惑

我正在尝试使用unique_ptr使用SDL_Surface的自定义删除器类型。这只是一个使用int的示例打字,但我希望你明白了。#include#include#includetypedefintSDL_Surface;SDL_Surface*CreateSurface(){SDL_Surface*p=newSDL_Surface;returnp;}voidFreeSurface(SDL_Surface*p){deletep;}intmain(){std::unique_ptr>uptr_1;//howtoassignavaluetouptr_1andthedeleter?retur

c++ - 成员初始化列表中的 unique_ptr

编辑:我知道unique_ptr是不可复制的,只能移动。我不明白初始化列表会发生什么。为什么成员初始化列表中的unique_ptr可以像代码片段中那样工作?#includeclassMyObject{public:MyObject():ptr(newint)//thisworks.MyObject():ptr(std::unique_ptr(newint))//ifoundthisinmanyexamples.butwhythisalsowork?//ithinkthisisusingcopyconstructorasthebottom.{}MyObject(MyObject&&oth

c++ - 我可以通过引用函数来传递 auto_ptr 吗?

下面的函数OK吗:voidDoSomething(auto_ptr&a).... 最佳答案 你可以做到,但我不确定你为什么要这样做。如果您使用auto_ptr来指示ptr的所有权(正如人们通常所做的那样),那么如果您想将ptr的所有权转移给函数,则只需将auto_ptr传递给函数,在这种情况下您将按值传递auto_ptr:voidDoSomething(auto_ptra)因此任何调用DoSomething的代码都会放弃ptr的所有权:auto_ptrp(newint(7));DoSomething(p);//pisnowempty

c++ - 将 std::unique_ptr 与标准容器一起使用

当我意识到C++11添加了unique_ptr时,我一直在寻找一种方法来实现安全vector和动态指针映射。我研究了如何在Google上使用它们,但未能找到详细信息。我需要知道的是:除了自动内存收集之外,指针和unique_ptr之间到底有什么不同?如何从vector或map中删除unique_ptr?除了删除迭代器之外,我还必须使用任何特殊代码吗? 最佳答案 没有。unique_ptr只是一个指针的包装器,它会在unique_ptr被销毁时删除指针。它没有开销(就像它替换的auto_ptr模板一样)。不,它会起作用的。困难实际上来

c++ - 独立的 shared_ptr<T> 实现?

有人知道我可以在我的程序中使用的TR1shared_ptr(可能还有其他智能指针)的开源独立实现吗?备注:“shared_ptr的独立实现”表示shared_ptr自身需要是独立的。强不只是包含库。所以请不要提升! 最佳答案 shared_ptr的boost实现完全是头文件,因此安装boost以使用它就像下载boost并将其添加到编译器的头文件搜索路径一样简单。这对boost来说并不比任何其他独立实现更难。如果你只想提取shared_ptr组件来进行单独的分发,那么你可以使用BoostBCP.

c++ - 使用 unique_ptr 控制文件描述符

理论上,我应该能够使用自定义指针类型和删除器,以便让unique_ptr管理一个不是指针的对象。我尝试了以下代码:#ifndefUNIQUE_FD_H#defineUNIQUE_FD_H#include#includestructunique_fd_deleter{typedefintpointer;//Internaltypeisapointervoidoperator()(intfd){close(fd);}};typedefstd::unique_ptrunique_fd;#endif//UNIQUE_FD_H这不起作用(带有-std=c++11参数的gcc4.7)。它响应以下错

c++ - 为什么复制 const shared_ptr& 不会违反 const-ness?

尽管我的代码编译得很好,但这一直困扰着我,我无法在stackoverflow上找到答案。以下通用构造函数是将shared_ptr传递给构造函数中的类实例的一种方法。MyClass{MyClass(conststd::shared_ptr&pt);std::shared_ptrpt_;//EDITED:Removed&typo};MyClass::MyClass(conststd::shared_ptr&pt):pt_(pt){}这编译得很好。我的问题如下:在我的理解中,像这样声明一个参数const:voidmyfunc(constT&t)promise不改变t。但是,通过将shared

c++ - 为什么让 operator new 私有(private)中断 std::shared_ptr?

我正在实现一个多态类型(称之为A),我想通过std::shared_ptr专门管理它。为了允许在派生类的构造函数中使用shared_from_this,A使用new分配,然后初始化一个成员std::shared_ptr给自己自动管理它的生命周期。为了帮助实现这一点,我决定将类特定的operatornew设为私有(private),并计划使用create()辅助函数而不是new和make_shared。该设计可能看起来有点滑稽,但在我正在处理的UI库的上下文中是有意义的。一个最小的可重现示例如下:structA{A():m_sharedthis(this){}voiddestroy(){

c++ - 尝试从 vector 中获取 unique_ptr 元素后出错

我阅读了有关如何插入unique_ptr的信息进入vector>:WhycanInotpush_backaunique_ptrintoavector?但是我如何取回一个元素呢?我举了个例子:#include#includeclassA{public:A(intx,inty){x_=x;y_=y;}private:intx_;inty_;};intmain(){std::vector>vec_a;std::unique_ptrtmp_a=std::unique_ptr(newA(13,32));vec_a.push_back(std::move(tmp_a));vec_a.push_ba