草庐IT

make_pair

全部标签

c++ - C++ 中的 "As a rule of thumb, make all your methods virtual"- 合理的建议?

我只是偶然看到了标题中的陈述。完整的报价是:Asaruleofthumb,makeallyourmethodsvirtual(includingthedestructor,butnotconstructors)toavoidproblemsassociatedwithomissionofthevirtualkeyword.我在Wrox的书ProfessionalC++中找到了这个。Youcangoogleittocheck.这有什么关系吗?我原以为您只会提供选择的扩展点,而不是默认的可扩展性。例如,a2001articlebyHerbSuttersaysso.从那以后,有什么发生了巨大

c++ - 为什么 boost 没有 make_scoped()?

Boost的make_shared()函数promise在尝试创建shared_ptr时是异常安全的.为什么没有make_scoped()相等的?是否有通用的最佳做法?这是来自boost::scoped_ptrdocumentation的代码示例这对我来说似乎不安全:boost::scoped_ptrx(newShoe);这行代码会依次完成这三件事:为Shoe分配堆内存调用Shoe的构造函数调用boost::scoped_ptr的构造函数如果Shoe的构造函数抛出异常,内存将被泄露。(参见R.MartinhoFernandes的回答)scoped_ptr不会处理释放,因为它还没有被构造

c++ - 如何make_shared派生类?

我想使用make_shared带有派生类的函数,如下所示classBase{public:typedefstd::shared_ptrPtr;};classDerived:publicBase{};Base::PtrmyPtr=std::make_shared(/*Derived()*/);我如何告诉make_shared构建这样一个对象?我想避开经典Base::Ptrptr=Base::Ptr(newDerived());利用make_shared函数中的单个alloc。 最佳答案 std::shared_ptr有一个可以生成sh

c++ - make_unique数组,原始提案与最终提案

StephanTLavavej最初对make_unique的建议是N3588它包括以下功能:make_unique(args...)make_unique_default_init()make_unique(n)make_unique_default_init(n)make_unique_value_init(n,args...)make_unique_auto_size(args...)但是,最后的提案N3656仅包含make_unique(两种形式)。我找不到有关该函数其他形式的任何讨论。我读了theminutesoftheBristolmeeting,但他们甚至都没有引用原始建议

c++ - std::make_shared 与 std::initializer_list

#include#includeclassBase{public:Base(){}};classDerived:publicBase{public:Derived(){}Derived(std::initializer_list>>){}};intmain(intargc,char**argv){autoexample=newDerived({{0,std::make_shared()}});return0;}它正常工作(livepreview),但是当我尝试使用std::make_shared和std::initializer_list作为参数时,我得到了错误:autoexample

c++ - 使用 pair<int, int> 作为 map 的键

基于previousquestion,我正在尝试使用一对整数作为键创建映射,即map,int>我找到了有关如何插入的信息:#include#includeusingnamespacestd;intmain(){map,int>mymap;mymap.insert(make_pair(make_pair(1,2),3));//edited}但我似乎无法访问该元素!我试过cout但它显示错误,我找不到有关如何使用key访问元素的信息。我做错了吗? 最佳答案 您需要一对作为keycout您目前拥有的cout语法不正确。

c++ - 如何将 std::pair 视为两个单独的变量?

标准库中有几个函数,如std::map::insert,它返回一个std::pair。有时,将其填充对应于该对的一半的两个不同变量会很方便。有没有简单的方法可以做到这一点?std::map::iteratorit;boolb;magic(it,b)=mymap.insert(std::make_pair(42,1));我在这里寻找魔法。 最佳答案 std::tie来自标题就是你想要的。std::tie(it,b)=mymap.insert(std::make_pair(42,1));“magic”:)注意:这是一个C++11特性。

c++ - 为什么 `std::pair<int, movable>` 需要 [deleted] `const&` 复制构造函数?

我正忙于测试各种通用算法的实现,并且我正在使用对所提供函数的支持最少的类型。我在使用std::pair时遇到了这个奇怪的设置某些类型T(例如int)和movable类型定义如下:structmovable{movable(){}movable(movable&&)=default;//movable(movableconst&)=delete;movable(movable&)=delete;};这个想法是有一个可移动但不可复制的类型。这很好用,例如,使用这样的表达式:movablem1=movable();movablem2=std::move(m1);但是,当尝试将此类型用作std

c++ - 将 move 语义与 std::pair 或 std::tuple 一起使用

假设您想利用move语义,但您的一个可move类需要成为std::pair的一部分。目的是创建一个返回std::pair的函数,该函数可以被视为右值并转发。但我不知道如何做到这一点,除非对std::pair本身进行内部更改,以使其了解move语义。考虑以下代码:structFoo{Foo(){}Foo(Foo&&f){}private:Foo(constFoo&f){}//donotallowcopying};intmain(){Foof;std::pairres=std::make_pair(f,10);//failsduetoprivatecopyconstructor}问题在于s

c++ - std::weak_ptrs 是否会影响 std::make_shared 分配的内存何时被释放?

如果我调用std::make_shared(而不仅仅是显式分配shared_ptr)那么出于性能原因,我希望引用计数与T的实例一起分配在内存中。一切顺利。但如果我有weak_ptr引用同一个对象的实例,大概他们需要访问该引用计数,以了解该对象是否仍然存在。因此,当T的实例的最后一个shared_ptr被销毁时,对系统的幼稚理解会暗示它无法释放存储T的内存,因为weak_ptrs仍然需要访问该计数。好像有一个separateweakreferencecounter从理论上讲,它可以与T的实例分开保存,以便可以在弱引用仍然存在的情况下销毁T并释放内存。但随后我们又回到了2个单独的分配,从而