草庐IT

pairing_iterator

全部标签

C++ 模板 std::vector::iterator 错误

在C++中,我试图获得std::vector::iterator对于我的模板类。但是,当我编译它时,出现错误:errorC2146:syntaxerror:missing';'beforeidentifier'iterator',errorC4430:missingtypespecifier-intassumed.Note:C++doesnotsupportdefault-int.我也收到警告:warningC4346:'std::vector::iterator':dependentnameisnotatype:#includetemplateclassv1{typedefstd::

c++ - 可以安全地存储 list::iterator 供以后使用吗?

假设我有一个列表,其中没有添加或删除新节点。但是,节点可能会被打乱。保存一个迭代器,指向列表中的一个节点,并在以后任意时间访问它是否安全?编辑(后续问题):list::splice()的文档说它从参数列表中删除元素。这是否意味着如果我调用splice,使用相同的列表作为函数的参数,现有的迭代器将失效? 最佳答案 是的。迭代器进入列表的标准受赠者不会失效,除非他们指向(比喻地说)的项目从列表中删除。从这个页面:http://www.sgi.com/tech/stl/List.htmlListshavetheimportantprope

c++ - 为什么 reverse_iterator 双重定义其嵌套类型?

似乎迭代器适配器reverse_iterator双重定义了它的大部分嵌套类型。特别是,它公开继承自std::iterator,它公开了iterator_category、value_type、difference_type、指针和引用。除了iterator_category和value_type外,这些都在类定义中再次显式typedef。24.5.1.1类模板reverse_iterator[反向迭代器]namespacestd{templateclassreverse_iterator:publiciterator::iterator_category,typenameiterato

c++ - 移动到未初始化的内存,或者 raw_storage_iterator 是如何工作的

我想将一系列对象移动到未初始化的内存中(使用移动构造)。由于std::uninitialized_copy没有move-counterpart,我想到了两个选项:使用std::move和raw_storage_iterator,或求助于手动循环:T*dest=get_memory();//optiononestd::move(first,last,std::raw_storage_iterator(dest));//optiontwofor(autoi=first;i!=last;++i,++dest){new(dest)T(std::move(*i));}第一个选项会执行移动构造(因

c++ - 为什么 std::sub_match<T> 公开继承自 std::pair<T, T>?

我正在阅读std::sub_match的文档并看到它公开继承自std::pair.自sub_match只是一对迭代器变成了一个字符序列,加上一些额外的功能,我可以理解它是用一个pair实现的,但为什么要使用公共(public)继承呢?从std::pair公开继承的问题与从大多数其他标准类公开继承相同:它们并不意味着要进行多态操作(特别是它们没有定义虚拟析构函数)。其他成员也将无法正常工作,即赋值运算符和交换成员函数(它们不会复制matched的sub_match成员)。为什么Boost开发人员和委员会决定实现sub_match通过公开继承pair而不是使用组合(如果他们想通过first

c++ - std::ostream_iterator 未找到运算符<<

我已经声明了一个operator对于std::pair:std::ostream&operator&p){o我想在打印数据时使用这个运算符:std::vector>data;std::copy(data.begin(),data.end(),std::ostream_iterator>(std::cout,"\n"));但是编译器说,nomatchforoperator...我做错了什么? 最佳答案 std::copy找不到operator的重载对于std::pair在std命名空间。没有什么好办法,重载operator对于来自st

c++ - 为什么将 set::iterator 而不是 const_iterator 传递给函数会违反单一定义规则?

std::set的描述容器givenbycppreference.com最后包含此注释:Themembertypesiteratorandconst_iteratormaybealiasestothesametype.Sinceiteratorisconvertibletoconst_iterator,const_iteratorshouldbeusedinfunctionparameterliststoavoidviolationsoftheOneDefinitionRule.我不明白最后这句话。我的理解是一个集合不允许修改它的元素(如果你需要改变一个,你必须erase它然后inse

c++ - 运行时错误 : map/set iterators incompatible

我在第8行遇到运行时错误“map/setiteratorsincompatible”。voidManager::Simulate(Military*military,Shalishut*shalishut,char*args[]){Simulation*simulation=Simulation::GetInstance();Time*time=Time::GetInstance();multimap::iteratoritTasks;itTasks=simulation->GetTasks().begin();while(itTasks!=simulation->GetTasks()

kotlin - 为什么 Kotlin Pair 中的条目不可变?

我有一个MutableListofPairs,我想减少第一个条目的值,所以我的条件是通过(更改):while(n>0){if(sibice[i].first>0){sum+=sibice[i].second//sibice[i].first--willnotcompilen--}elsei++}但是Pair类不允许我这样做,除了创建我自己的对之外还有其他解决方法吗?为什么会出现这种情况? 最佳答案 与所有实体一样,可变性也会出现问题。在您的情况下,您可以使用一对新值更新列表条目。valnewPair=oldPair.copy(fir

kotlin - 为什么 Kotlin Pair 中的条目不可变?

我有一个MutableListofPairs,我想减少第一个条目的值,所以我的条件是通过(更改):while(n>0){if(sibice[i].first>0){sum+=sibice[i].second//sibice[i].first--willnotcompilen--}elsei++}但是Pair类不允许我这样做,除了创建我自己的对之外还有其他解决方法吗?为什么会出现这种情况? 最佳答案 与所有实体一样,可变性也会出现问题。在您的情况下,您可以使用一对新值更新列表条目。valnewPair=oldPair.copy(fir