草庐IT

auto_ptr_ref

全部标签

C++ set 和 shared_ptr

我有X类:classX{public:booloperator然后我有以下代码:std::multiset>m;我的问题是:m中的数据是如何排序的?X(shared_ptr)的地址或X.operator?如果按地址X订购,我怎样才能按X.operator订购呢??为此m,如果我想从小到大访问它的元素,下面的代码能保证吗?如果没有,怎么办?for(auto&i:m){f(i);} 最佳答案 您的集合是根据您的key_type排序的,即std::shared_ptr.作为您的std::shared_ptr是comparable,std:

c++ - 为 std::shared_ptr 指定一个删除器,它适用于特定类型或其派生类型的所有对象

我的项目中有以下类classBase{public:virtual~Base(){};}classDer1:publicBase{public:virtual~Der1(){};}classDer2:publicBase{public:virtual~Der2(){};}我将这些类的对象保存为std::shared_ptr。我需要为类型为Base或其任何derivedtypes的所有对象提供自定义删除器。我想要的删除方法中的代码将对所有这些对象做同样的事情,比如classDeleter{public:voidoperator()(Base*b){//Dosomethingdeleteb

c++ - std::shared_ptr:带有自定义删除器的 typedef

这个问题在这里已经有了答案:Typedefashared_ptrtypewithastaticcustomdeleter,similartounique_ptr(2个答案)关闭7年前。我正在使用SDL2开发C++应用程序,并希望使用shared_ptr来保存指针内容。所以我做例如这个:typedefstd::shared_ptrSDLWindowPtr;而且我需要在整个过程中使用自定义删除器。是否可以将其包含在typedef中?如果是,如何?删除函数称为SDL_DestroyWindow。如果没有,如何让shared_ptr使用SDL_DestroyWindow作为自定义删除函数?提前

c++ - 为什么 `auto&` 不能绑定(bind)到 volatile 右值表达式?

考虑下面的代码:intmain(){inti{};auto&c=static_cast(i);//(1)auto&v=static_cast(i);//(2)}(1)编译成功,(2)不被接受:error:volatilelvaluereferencetotype'volatileint'cannotbindtoatemporaryoftype'volatileint'为什么auto不能变成volatileint?为什么auto&可以变成constint并绑定(bind)到constint&&?是因为auto&实际上绑定(bind)到一个在赋值右侧创建的临时对象吗?但是,为什么auto&

c++ - 为什么auto_ptr中有模板复制构造函数和重写操作函数?

为什么auto_ptr中有模板复制构造函数和重写操作函数?C++的ISO标准为auto_ptr指定了以下接口(interface)。(这是直接从2003年的标准中复制出来的。)namespacestd{templatestructauto_ptr_ref{};templateclassauto_ptr{public:typedefXelement_type;//20.4.5.1construct/copy/destroy:explicitauto_ptr(X*p=0)throw();auto_ptr(auto_ptr&)throw();templateauto_ptr(auto_ptr

c++ - 构造一个 constexpr std::weak_ptr

根据std::weak_ptr文档可以构造一个constexprweak_ptr:#includeconstexprweak_ptrfoo{};但是,使用clang尝试此操作会产生编译错误,提示constexpr变量不能具有非文字类型'conststd::weak_ptr',这是因为weak_ptr有一个用户提供的析构函数。(确实如此,查看libc++header)我的问题是,这是一个libc++错误,还是做constexprweak_ptr只是没有意义并且拥有constexpr默认构造函数是一个错误?我可以期待它在未来发挥作用吗? 最佳答案

c++ - 为什么存在 shared_ptr 的原子重载

为什么有shared_ptr的原子重载,如here所述而不是为处理shared_ptr的std::atomic专门化。似乎与其余C++标准库采用的面向对象模式不一致。在使用shared_ptr实现readcopyupdateidiom时,为了确保我做对了我们需要通过这些函数对共享指针进行所有访问(读取和写入)吗? 最佳答案 因为:std::atomicmaybeinstantiatedwithanyTriviallyCopyabletypeT.来源:http://en.cppreference.com/w/cpp/atomic/at

c++ - constexpr-if-else 主体能否在 constexpr auto 函数中返回不同类型?

我正在尝试编写一个函数,根据枚举的运行时值将值的枚举映射到一组类型。我意识到您不能根据枚举的运行时值返回不同的类型,因为编译器不知道要分配多少堆栈空间。但是,我正在尝试将其编写为constexpr函数,使用新的if-constexpr功能来实现它。我收到来自clang的错误,提示我使用了非法指定的模板参数。有人知道如何实现吗?编辑:这是一个更容易理解的版本,更简洁地展示了我的问题:http://coliru.stacked-crooked.com/a/2b9fef340bd167a8旧代码:#include#include#includenamespace{enumclassshape

c++ - 制作一个 const unique_ptr 然后尝试从它 std::move 给出相同的错误,就好像您试图访问复制构造函数一样

当我们尝试复制unique_ptr(例如,将一个唯一指针分配给另一个)时,我注意到错误是ErrorC2280std::unique_ptr#includeintmain(){std::unique_ptra=std::make_unique(2);std::unique_ptrb=a;}没关系,因为unique_ptr没有定义复制构造函数。您不会从唯一指针进行复制以在它们之间move(转移指针的所有权)。有趣的是(好吧,也许不是),这段代码抛出了同样的错误。现在我知道它是无效的(我将第一个unique_ptr声明为不可变对象(immutable对象)),但错误消息暗示它正在尝试调用复制

c++ - 引用 unique_ptr 的 vector

我有一组unique_ptr。在这里我想拿走其中的一些并将它们返回给调用者。调用者只需要读取内容,所以我想使用常量引用。但我不确定如何使用unique_ptr来做到这一点。这是我用来使用原始指针执行此操作的一些代码:classentry{};vectormaster;constvectorget_entries(){vectorentries;//peusocode,mastercontainsallentries.//onlysomeentriesarecopied,filteredbysomepredicatecopy_if(master.begin(),master.end(),