jjzjj

iterable

全部标签

java - 为什么这么多方法使用 Collection 而不是 Iterable?

有了C#,我逐渐爱上了IEnumerable界面。在很多情况下,这就是您想要提供和接受的全部内容。此外,它在.Net库中也很有用。例如,您在List上有一个构造函数需要IEnumerable的类(class).我现在必须使用Java,自然想使用等效的Iterable界面。但是,似乎我真的不能在任何地方使用它。一切似乎都在使用扩展的Collection接口(interface)代替。为什么是这样?例如,您有ArrayList采用Collection的构造函数:Constructsalistcontainingtheelementsofthespecifiedcollection,inth

java:分页结果的设计模式

所以有Iterable和Iterator和List。如果您试图为其他Java代码提供接口(interface),以便封装由返回“页面”结果的远程服务提供的功能,您会使用什么?例如,考虑一个数据库或网页(例如flickrAPI)。在第一次检索结果后,您知道结果的总数和前N个结果,但在检索其余结果之前,您不知道剩余的结果。 最佳答案 在您的情况下,鉴于每个元素的检索成本都很高,因此获取聚合结果而不是在删除调用级别直接迭代每个元素可能是有意义的。您可以提供一种返回列表的方法,如下所示:ListgetResults(intoffset,in

java - Iterator 实现应该如何处理已检查的异常?

我将java.sql.RecordSet包装在java.util.Iterator中。我的问题是,如果任何记录集方法抛出SQLException,我应该怎么办?java.util.Iteratorjavadoc解释在各种情况下抛出哪些异常(即NoSuchElementException,以防您在最后一个元素之后调用next())但是,它没有提到当出现完全不相关的问题时该怎么做,例如网络或磁盘IO问题。简单地在next()和hasNext()中抛出SQLException是不可能的,因为它与Iterator接口(interface)不兼容。这是我当前的代码(已简化):publicclas

java - 在 java.util.Collection 和 java.lang.Iterable 中声明的方法 iterator(),它的超接口(interface)?

有人可以向我解释为什么方法是Iteratoriterator();吗?在java.util.Collection中定义?Collection已经扩展java.lang.Iterable;这种方法是多余的。这是为了方便吗? 最佳答案 CollectioninterfaceJava1.2中引入了CollectionsAPI。iterator方法出现了。然而,Iterableinterface直到Java1.5才被引入。Collection显式定义iterator的原因是因为它早于Iterable。Collection返回Iterator

java - JSTL 消息 : Don't know how to iterate over supplied "items" with forEach

我正在将一个列表传递给,但我收到错误消息,指出它不知道如何对其进行迭代。@RequestMapping("/viewall")publicStringviewAll(Modelmodel){//productService.findAllProducts()returnsListmodel.addAttribute("everything",productService.findAllProducts());//Alsotriedusingiterator,butIgetsameerror//model.addAtrribute("everything",productService.

java - 通用列表打印方法

我正在尝试编写一个适用于所有实现“可迭代”接口(interface)的类的通用打印方法publicclassList{publicstatic>voidprint(T[]list){for(Objectelement:list){System.out.println(element);}}publicstaticvoidmain(String[]args){ArrayListl=newArrayList();l.add(1);l.add(5);l.add(3);l.add(2);print(l);}}但我收到错误消息“类型列表中的方法print(T[])不适用于参数(ArrayList

java - 解释如何将此 lambda 分配给 Iterable

我在thispost上遇到了一些聪明的代码,可以将Iterator转换为来自Karol的Stream.我不得不承认,我不完全理解如何允许将lambda分配给以下代码中的Iterable类型...staticStreamiteratorToFiniteStream(finalIteratoriterator){finalIterableiterable=()->iterator;returnStreamSupport.stream(iterable.spliterator(),false);}我决定编写自己的小测试以确保它能够编译和执行,而且确实如此。publicvoidprintsSt

java - 迭代器接口(interface)

我有一个大学作业,要求我实现一个实现Iterator接口(interface)的内部类。迭代器在单链表父类(superclass)上工作。目前我的内部类是这样的:privateclassListIteratorimplementsIterator{Nodetemp;booleannextCalled=false;ListIterator(Nodefo){this.temp=fo;}@OverridepublicbooleanhasNext(){if(temp!=null){returntrue;}returnfalse;}@OverridepublicVnext(){nextCalle

java - iterable.forEach() 和 iterable.stream().forEach() 的区别

这个问题在这里已经有了答案:WhatisdifferencebetweenCollection.stream().forEach()andCollection.forEach()?(5个答案)关闭8年前。看起来我可以直接在我的集合上调用list.forEach(a->a.stuff()),而不是list.stream().forEach(a->a.stuff())。我什么时候会使用一个而不是另一个(parallelStream()除了..)?

java - Iterables.find 和 Iterators.find - 不是抛出异常,而是获取 null

我正在使用google-collections并尝试找到第一个满足Predicate的元素,如果不满足,则返回'null'。不幸的是,当没有找到元素时,Iterables.find和Iterators.find会抛出NoSuchElementException。现在,我不得不做Objectfound=null;if(Iterators.any(newIterator(...),my_predicate){found=Iterators.find(newIterator(...),my_predicate)}我可以用“try/catch”包围并做同样的事情,但对于我的用例,我会遇到很多没