草庐IT

skeleton-pair-insert-maybe

全部标签

C++ std::pair, std::vector 和 memcpy

从a的第一个元素的内存地址memcopymyvect.size()*sizeof(foo)字节是否安全std::vector>myvect放入一个数组structfoo{T1first;T2second;}如果数组分配的元素数量与vector的大小相同?谢谢 最佳答案 不,一个包含T1的类和T2不保证与std::pair相同的布局或对齐方式,至少在C++98中是这样(因为std::pair不是POD类型)。在C++0x中情况可能有所不同。 关于C++std::pair,std::vect

c++ - 如何在另一个 std::pair 中插入一对 std::pair?

我正在声明一个字符串映射到一对对,如下所示:std::map,std::pair>>reference;我将其初始化为:reference.insert(L"First",std::pair,std::pair>(std::pair(-1,-1),std::pair(0,0)));但是,VisualC++给我错误“C2664,没有构造函数可以采用源类型,或者构造函数重载解析不明确”。我是使用模板和STL的新手,我不知道我做错了什么。 最佳答案 >>>无法正确解析(除非你有C++0x编译器)。更改为>>>这个:reference.in

c++ - make_pair 命名空间污染

在我最近编写的代码中,我注意到一个奇怪的行为。当我使用第一个参数为std::pair的make_pair时,make_pair变得“神奇地”在命名空间中可用(我不必使用std::限定符)#includeintmain(){inti1=2;inti2=10;inti3=0;//constructingapairusingstd::make_pair,everything'sokaystd::pairkey=std::make_pair(i1,i2);//here,whyismake_pairsuddenlymagicallyavailablewithoutthe//std::namesp

c++ - 我可以始终使用 std::inserter(container, container.end()) 而不是 std::back_inserter(container) 吗?

std::back_inserter仅适用于带有push_back的容器,因此它不适用于set和map另一方面,std::inserter适用于所有容器类型。那么我可以一直使用std::inserter(container,container.end())吗?那么下面的代码是否适用于所有类型的容器?templateTContainercreate(TElementelement){TContainercontainer;autoinserter=std::inserter(container,container.end());for(inti=0;i>(1);create>(1);

c++ - 为 std::pair<int, int> 重载运算符>>

我正在尝试使用boost::lexical_cast在std::pair上.#include#include#includenamespacemy{//Whenmy_pairisauserdefinedtype,thisprogramcompiles//andrunswithoutanyproblems.//Whendeclaringmy_pairasanaliasofstd::pair,//itfailstocompile/*structmy_pair{intfirst;intsecond;};*/usingmy_pair=std::pair;std::istream&operato

c++ - 如果我使用 vector::begin() 而不是 std::back_inserter(vector) 作为 set_intersection 的输出会怎样?

我一直在使用高度简洁和直观的C​​++语法来查找两个排序的vector的交集并将结果放入第三个vector:vectora,b,c;//...std::set_intersection(a.begin(),a.end(),b.begin(),b.end(),std::back_inserter(c));这应该将c设置为intersection(a,b),假设a和b已排序。但是如果我只使用c.begin()会怎么样(我想我在某个地方看到了一个例子,这就是我这样做的原因):std::set_intersection(a.begin(),a.end(),b.begin(),b.end(),c

c++ - std::map 和 std::pair 的问题

我想执行一个小程序来测试一些东西#include#includeusingnamespacestd;struct_pos{floatxi;floatxf;booloperatorxim;struct_posk1={0,10};struct_posk2={10,15};struct_valv1={5.5};struct_valv2={12.3};m.insert(std::pair(k1,v1));m.insert(std::pair(k2,v2));return0;}问题是当我尝试编译它时,出现以下错误$g++m2.cpp-omtestInfileincludedfrom/usr/in

c++ - [[maybe_unused]] 在枚举器上

查看[[maybe_unused]]的规范,它指出:Appearsinthedeclarationofaclass,atypedef­,avariable,anon­staticdatamember,afunction,anenumeration,oranenumerator.Ifthecompilerissueswarningsonunusedentities,thatwarningissuppressedforanyentitydeclaredmaybe_unused.正如这里提到的枚举器,我有点希望它有一个用例。因为我唯一能想出的是-Wswitch警告,所以我用Clang、GCC

c++ - 在 map 中使用 unique_ptr 时删除 std::pair 中的函数

我有一段C++代码,我不确定它是否正确。考虑以下代码。#include#include#includeusingnamespacestd;intmain(intargc,char*argv[]){vector>>v;v.resize(5);returnEXIT_SUCCESS;}GCC编译这段代码没有问题。然而,英特尔编译器(版本19)因错误而停止:/usr/local/[...]/include/c++/7.3.0/ext/new_allocator.h(136):error:function"std::pair::pair(conststd::pair&)[with_T1=cons

c++ - std::map emplace/insert 正在插入的移动值

目前我正在阅读C++1y论文,现在我正在尝试理解标题为Improvedinsertioninterfaceforunique-keymaps的n3873论文.该论文指出insert和emplace方法存在问题,它通过以下示例说明了该问题:std::map>m;m["foo"];std::unique_ptrp(newFoo);autores=m.emplace("foo",std::move(p));在上面的代码之后,它表达了以下内容:Whatisthevalueofp?Itiscurrentlyunspecifiedwhetherphasbeenmoved-from.(Theansw