草庐IT

back_emplace_iterator

全部标签

c++ - 实现 std::vector::push_back 强异常安全

我正在根据2018年后的圣地亚哥草案(N4791)实现我自己的vector,并且有一些关于实现强异常安全性的问题。这是一些代码:templatevoidVector::push_back(constT&value){if(buffer_capacity==0){this->Allocate(this->GetSufficientCapacity(1));}if(buffer_sizeConstruct(value);return;}autonew_buffer=CreateNewBuffer(this->GetSufficientCapacity(buffer_size+1),allo

c++ - 如何将 boost::spirit::lex token 的值从 iterator_range 转换为字符串?

当我尝试从iterator_range转换标记的值时,词法分析器在尝试读取下一个标记时失败。这是包含token定义的token结构:(我不认为这是相关的,但我包括以防万一。)templatestructTokens:boost::spirit::lex::lexer{Tokens();boost::spirit::lex::token_defidentifier;boost::spirit::lex::token_defstring;boost::spirit::lex::token_defboolean;boost::spirit::lex::token_defreal;boost:

c++ - 在这种情况下, std::stack::push() 和 std::stack::emplace() 之间有区别吗?

看这段代码:structDummy{intbla;intblabla;charcharacter;Dummy(intb,intbb,charc):bla(b),blabla(bb),character(c){}};std::stacks;Dummydummy;s.push(dummy);//(1)s.emplace(dummy);//(2)我看不出(1)和(2)之间的区别。我知道emplace()在为要添加的对象的构造函数提供参数时很有用,例如:s.emplace(1,2,'c');但我不知道我描述的情况有什么区别,因为push()和emplace()都应该引用本地dummy对象并使用

c++ - 将 initializer_list 插入 std::vector 时出现 "Invalid iterator range"

此代码在Ideone上按预期编译并运行良好:#include#include#includeintmain(){std::vectorstrVec;strVec.insert(strVec.end(),{L"black",L"white",L"red"});strVec.insert(strVec.end(),{L"blue",L"green"});//STLexceptionfor(auto&i:strVec){std::wcout但是,在MSVC(VisualStudio2013)中因“无效的迭代器范围”而失败。有什么见解吗?顺便说一句,插入更多元素是可行的,例如在第二个插入中,这

c++ - 在使用迭代器和 pop_back 循环时出现单一迭代器错误

给出下面的代码(假设它被命名为deque.cpp)#include#includeintmain(){std::dequed={1,2,3};for(autoit=d.rbegin();it!=d.rend();){printf("it:%d\n",*it);++it;d.pop_back();}return0;}用g++-std=c++11-odequedeque.cpp编译,运行良好:$./dequeit:3it:2it:1但是,如果使用-D_GLIBCXX_DEBUG(g++-std=c++11-odeque_debugdeque.cpp-D_GLIBCXX_DEBUG编译,它会

c++ - 当您无法测量差异时如何处理 iterator::difference_type?

我正在为第3方C库编写C++包装器。该库提供了一些用于迭代一系列对象的函数。我想编写一个迭代器来包装此行为,以便迭代更容易,但我想不出我将如何提供强制性的“差异”类型,因为迭代对象没有有意义的相对顺序和API我正在使用不提供提前查找可用对象数量的方法。我无法在迭代时对对象进行计数,因为尽管这可以解决单个迭代器,但它会导致end()迭代器和其他迭代器之间的差异未定义。 最佳答案 C++中的所有迭代器都需要提供某种difference_type。该类型是否有意义或有用是一个完全不同的问题。根据您的描述,您似乎正在使用输入迭代器,它使您能

c++ - 为什么会出现运行时错误 : Vector erase iterator outside range

我遇到了以下代码的奇怪运行时错误:#include#includeusingstd::vector;structData{intid;};intmain(){vectormylist;Datam;m.id=10;mylist.push_back(m);mylist.erase(std::remove_if(mylist.begin(),mylist.end(),[](constData&m){returnm.id>100;}));return0;}错误说:Vectoreraseiteratoroutsiderange我不是在解决了类似Ref1的问题之后,Ref2但意识到问题的原因以及我

c++ - 你怎么能 emplace_back 错误的类型呢?

我有一个doublevector。但是我打错了我打算这样写:std::vectortimestamp;但我是这样写的:std::vector>timestamp;但是,这样编译timestamp.emplace_back(a_double_timestamp)我正在安置一个double进入std::vector>.double不是std::vector 最佳答案 double隐式转换为size_type,作为thevectorconstructor的参数:explicitvector(size_typecount);因此,如果你通过

C++ : Math library that solve system of equations using back substitution algorithm

如果我有这个:A*f=g;A:uppertriangularmatrix(nxn)f:(nx1)g:(nx1)需要使用反向替换算法求解f。我会说自己写一个并没有那么难,但是哦,如果那里有图书馆,那为什么不呢。 最佳答案 提升uBlas应该管用。至少如果我正确理解你的问题,你可能想从查看lu_substitute()和inplace_solve()开始。 关于C++:Mathlibrarythatsolvesystemofequationsusingbacksubstitutionalgo

c++ - 如何从CGAL中的Edge_iterator获取源点和目标点

我对某些点进行了Delaunay三角剖分,并希望按长度升序迭代其中的所有边,以构建最小跨度线程。我试过以下方法,但无法编译:typedefCGAL::Exact_predicates_inexact_constructions_kernelK;typedefCGAL::Delaunay_triangulation_2T;typedefK::Point_2P;typedefT::Vertex_handleVh;typedefT::Vertex_iteratorVi;typedefT::Edge_iteratorEi;boolsortFunction(Eia,Eib){K::FTla,lb