jjzjj

iterable

全部标签

java - 在 Java 中设计迭代器

我遇到过很多需要迭代器的问题。通常,它们很简单,您已经拥有可以遵循的底层数据结构。其他时候,它会变得更复杂。一个示例是使用中序遍历在没有父链接的情况下迭代BST。这需要您执行以下操作:在构造函数中创建一个堆栈。迭代到最左边的节点。存储有更多节点要访问以便从hasNext()轻松返回。存储要访问的下一个节点,以便从next()轻松返回。您可以在hasNext()或next()中定位下一个节点。您还可以在构造函数中或在对hasNext()的第一次调用中定位第一个节点。我的问题对于在迭代器实现中在哪里完成大部分工作,是否有标准或最佳实践?一种方式比另一种方式“更清洁”吗?

java - 流接口(interface) : How empty() method returns Iterable?

@FunctionalInterfacepublicinterfaceStreamableextendsIterable,Supplier>我正在探索StreamableInterface,我遇到的第一个方法是empty()具有以下定义的方法。staticStreamableempty(){returnCollections::emptyIterator;}Collections::emptyIterator返回Iterator但是这个方法的返回类型是Streamable.Streamble扩展了Iterable和Supplier而不是Iterator接口(interface)。我不明

java - 增强的 for 循环不接受 Iterator

如果之前有人问过这个问题,请原谅。我的搜索没有提出任何其他类似的问题。这是让我在Java中感到惊讶的事情。显然,增强的for循环只接受java.lang.Iterable的数组或实例。.它不接受java.util.Iterator作为迭代的有效对象引用。例如,Eclipse显示以下代码的错误消息。它说:“只能迭代数组或java.lang.Iterable的实例”SetmySet=newHashSet();mySet.add("dummy");mySet.add("test");Iteratorstrings=mySet.iterator();for(Stringstr:strings)

java - 例如,将 Iterator<Object> 转换为 Set<String> 的最佳方式

类型转换Iterator到Set什么是最干净/最佳的实践方式? 最佳答案 publicSetgetBs(){Iteratoriterator=myFunc.iterator();Setresult=newHashSet();while(iterator.hasNext()){result.add((B)iterator.next();}returnresult;}当然,如果迭代器返回的所有A都不是B,它当然会失败。如果要过滤迭代器,那么使用instanceof:publicSetgetBs(){Iteratoriterator=my

java - 为什么 Iterators.size() 使迭代器为空?

publicstaticvoidmain(Stringargs[])throwsJSONException{JSONObjectjson=newJSONObject();json.put("name","abcgdj");json.put("no","1234");json.put("contact","6748356");Iteratorkeys=json.keys();System.err.println(Iterators.size(keys));System.err.println(Iterators.size(keys));}在这段代码中,在执行Iterators.size(

c# - 链表 <T> (2.0) : removing items iteratively

我需要遍历LinkedList(在.NET2.0中)并根据给定条件删除所有项目。这在Java下很简单,因为我可以执行以下操作:Iteratori=list.iterator();while(i.hasNext()){Ee=i.next();if(e==x){//Found,somoveittothefront,i.remove();list.addFirst(x);//Returnitreturnx;}}不幸的是,在IEnumerator的.NET行为中(相当于Iterator)没有remove方法从集合中删除当前元素。此外,在LinkedList无法访问给定索引处的元素,无法通过从最

java - 为什么 iterator.hasNext 不适用于 BlockingQueue?

我试图在BlockingQueue上使用迭代器方法,发现hasNext()是非阻塞的-即它不会等到添加更多元素,而是在没有元素时返回false。下面是问题:这是糟糕的设计还是错误的期望?有没有办法使用阻塞BLockingQueue的方法与它的父Collection类方法(例如,如果某些方法期望一个集合,我可以通过一个阻塞吗排队希望其处理将等到队列有更多元素)这是一个示例代码块publicclassSomeContainer{publicstaticvoidmain(String[]args){BlockingQueuebq=newLinkedBlockingQueue();SomeCo

java - Java 中 iterable<Integer> 的 Collections.max 函数

JavaCollections.max仅采用可排序对象的集合。然而,由于集合不一定排序,我看不出有任何理由不为可迭代类型实现相同的max函数。Iterable>是否有max方法?在Java的标准库中? 最佳答案 虽然Guava不是Java的标准库,但它已经足够接近了......Ecom.google.common.collect.Ordering#max(Iterableiterable)例如Tmax=Ordering.natural().max(myIterable);至于为什么标准库没有实现,可能是因为aCollectionmu

Java Iterator实现编译错误: does not override abstract method remove()

为什么会出现以下编译错误:LRIterator不是抽象的,不会覆盖java.util.Iterator中的抽象方法remove()注意,实现是针对链表的publicIteratoriterator(){returnnewLRIterator();}privateclassLRIteratorimplementsIterator{privateDLLNodeplace;privateLRIterator(){place=first;}publicbooleanhasNext(){return(place!=null);}publicObjectnext(){if(place==null)

java - 如何在 java 中从 Iterable 创建集合?

例如,我有一组几何图形:Setfigures;有两种图形:正方形和圆形。我想使用googlecollections获取一组正方形:Iterables.filter(figures,squarePredicate);但是过滤器方法返回Iterable...我如何从Iterable创建Set?(不在Iterable上使用循环) 最佳答案 我认为您需要重新考虑您的要求。你需要一组正方形。为什么?集合只为您提供唯一性和迭代性。您在Iterable中具有唯一性,因为源是一个集合,并且您可以迭代Iterable中的项目。那你为什么需要这套?只有