草庐IT

tok_iter

全部标签

java - List Iterator的add()方法对迭代器做了什么?

我希望能够向ArrayList中插入元素使用ListIterator,但不知何故,即使在阅读了与ListIterator的添加方法相关的文档后,我仍然感到困惑类,如果我做这样的事情for(inti=0;i这段代码片段对我的列表迭代器做了什么,它把列表迭代器移到了哪里?当我运行以下代码时,我得到的结果是“Hi”-:importjava.util.ArrayList;importjava.util.ListIterator;publicclassListIter{publicstaticvoidmain(String[]args){String[]s={"Hi","I","am","Ank

Java 8 流 : iterate over Map of Lists

我有以下对象和map:MyObjectStringname;Longpriority;foobar;Map>anotherHashMap;我想在另一个map中转换map。结果映射的键是输入映射的键。结果映射的值是我的对象的属性“名称”,按优先级排序。排序和提取名称不是问题,但我无法将其放入结果映射中。我用旧的Java7方式来做,但如果可以使用流式API就好了。Map>result=newHashMap();for(Stringidentifier:anotherHashMap.keySet()){ListgeneratedList=anotherHashMap.get(identifi

java - 包含 Iterable 和 Iterator 的方法?

是否有一种简单的方法来检查元素是否包含在可迭代对象或迭代器中,类似于Collection.contains(Objecto)方法?即而不是必须写:Iterabledata=getData();for(finalStringname:data){if(name.equals(myName)){returntrue;}}我想写:Iterabledata=getData();if(Collections.contains(data,myName)){returntrue;}我真的很惊讶没有这样的东西。 最佳答案 在Java8中,您可以将I

c++ - Erase-remove 习语 : what happens when remove return past-the-end-iterator?

我在阅读ScottMeyers的erase-removeidiom(第32项)时遇到了这个问题"EffectiveSTL”书。vectorv;...v.erase(remove(v.begin(),v.end(),99),v.end());remove基本上返回“新逻辑结束”和原始范围的元素,这些元素从范围的“新逻辑结束”开始并继续直到范围的真正结束是要删除的元素从容器中删除。听起来不错。现在,让我问我的问题:在上面的例子中,如果vectorv中没有找到99,remove可以返回v.end()。它基本上是将past-the-end-iterator传递给erase方法。当past-th

c++ - STL 算法如何独立于 Iterator 类型工作?

STL算法如何独立于迭代器类型工作? 最佳答案 真的,他们只是工作。它们使用模板的一些非常基本的属性,有时称为静态多态性。如果您熟悉该术语,它本质上是一种鸭式输入形式。(如果它长得像鸭子,而且叫起来像鸭子,那一定是鸭子)技巧很简单。这是一个非常简单的例子:templatevoidsay_hello(constT&t){t.hello();}say_hello函数不关心它的参数是哪种类型。它不必从接口(interface)派生或做出任何其他类型的关于它是什么的“promise”。重要的是类型在这种情况下有效。我们对该类型所做的一切就是

C++标准写法: Does "through all iterators in the range" imply sequentiality?

ThisSOquestion引发了关于std::generate和标准做出的保证的讨论。特别是,你能否使用具有内部状态的函数对象并依赖于generate(it1,it2,gen)来调用gen(),将结果存储在*it,再调用gen(),存入*(it+1)等,还是可以从后面开始,比如?标准(n3337,§25.3.7/1)是这样说的:Effects:Thefirstalgorithminvokesthefunctionobjectgenandassignsthereturnvalueofgenthroughalltheiteratorsintherange[first,last).Thes

c++ - 可以从 istream_iterator 制作 move_iterator 吗?

考虑以下代码:typedefistream_iteratorchar_itr;char_itreos;stringll("sometexthere");istringstreamline_in(ll);char_itrstart(line_in);move_iteratormstart(start);//!!!move_iteratormeos(eos);vectorvc(mstart,meos);上面的代码由于行(!!!)而无法编译:errorC2440:'return':cannotconvertfrom'constchar'to'char&&'但是,如果您分别用start和eos

c++ - 我如何定义 map::iterator 列表和 list::iterator 映射

我需要一个Map::iterator列表和List::iterator映射。我该怎么做:typedefstd::listList;typedefstd::mapMap;也许我可以使用迭代器的前向声明之类的东西? 最佳答案 像这样的东西应该可以帮助你:#include#include#include#include#includestructdecl_t{typedefstd::mapmap_t;typedefstd::list>list_t;list_t::iteratorit;};intmain(intargc,constchar

c++ - boost 图形库 : Bundled Properties and iterating across edges

只是想了解一下BoostGraphLibrary,我有几个问题。我正在编写一些代码,它是BGL图的包装类。我的想法是,我可以随心所欲地操作图表,然后调用包装方法以GEXF(XML)格式输出图表。我的代码是这样的:structVertex{std::stringlabel;...};structEdge{std::stringlabel;doubleweight;...};typedefboost::adjacency_listGraphType;templateclassGEXF{private:Graphgraph;...};templatevoidGEXF::buildXML(){

c++ - 具有不完整 Value 参数的 Boost.Iterator Facade

我正在尝试将boost::iterator_facade与不完整的Value一起使用模板参数。这失败了,因为iterator_facade正试图检查类型is_pod。这是预期的行为吗?我可以解决这个限制吗某种方式?我可以编写一个简单地代理foo和为它提供隐式转换,但我宁愿有一个更简单的解决方案。#includeclassiter:publicboost::iterator_facade{private:friendclassboost::iterator_core_access;voidincrement(){}boolequal(iterconst&other)const{retur