1

我对Java中的迭代器有点困惑。如何使 next() 仅返回某些值?比如说我有一个由 10 个元素组成的布尔数组,我只想返回那些为真的。我是否在 next() 方法中放置了一个条件来检查该条件并在满足时返回?还是在我实际使用迭代器时检查条件并继续调用 next() 直到我得到合适的值,然后使用该值?

同样,如果我有一个整数数组,并且我想创建数组的字符串表示形式,其中每个元素用空格分隔,但我只想使用负元素。如果我想使用迭代器执行此操作,我是在 next() 方法中检查负元素并仅返回下一个负值,还是检查何时进行字符串表示,并继续调用 next( ) 直到我得到一个负值,然后将该值添加到字符串中?

谢谢!

4

4 回答 4

12

普通的 Java 迭代器只是迭代集合的每个元素。因此,您必须在每次迭代时自己检查值。

您编写的内容可以使用Apache Commons CollectionsFilterIterator中的类来完成。

来自 JavaDoc:

这个迭代器装饰了底层迭代器,只允许通过那些匹配指定的元素Predicate

这是一个帮助您入门的示例:

// Create a predicate class, like this:
class MyAwesomePredicate implements Predicate {

    @Override
    public boolean evaluate(Object object) {

        // If the condition is satisfied, return true.
        // Return false otherwise.

    }     
}

// and pass it to the FilterIterator:
Iterator<SomeClass> matchingObjects = 
    new FilterIterator(myCollection.iterator(), new MyAwesomePredicate());

// Now iterate the maching objects:
while (machingObjects.hasNext() {

    // do your stuff

}

更新:如果您愿意,还有Iterators#filter(Iterator<T>, Predicate<? super T>)来自Guava的。与 Apache Commons 不同,它支持泛型,并且(可以说)更高的酷度因子

于 2012-06-27T07:49:26.817 回答
1

Iterator用于迭代集合,并将逐个返回每个元素。没有其他方法可以使用Iterator,因此请检查迭代或创建自己的特殊迭代器。

于 2012-06-27T07:47:22.827 回答
1

迭代器的概念非常简单:它在元素集合上隐藏(封装)遍历算法的实现。您调用 next - 它获取集合中的下一个元素,由您决定如何使用此值。通过使用迭代器,您不依赖集合的内部实现。当然,您可以创建自己的迭代器(它应该实现 java.util.Iterator 接口),但我相信您的要求不是必需的 :) 希望这会有所帮助

于 2012-06-27T07:48:52.103 回答
1

从技术上讲,两者都是可行的,所以这实际上是一个设计问题。如果您确定每次迭代该 Iterable 结构时都需要该条件,而不是使用 Iterator 子类的 next() 方法中的条件,否则,您最好在 Iterator 之外签入您的应用程序。

此外,next() 方法中的测试可能会提高性能,因为您将在应用程序代码中迭代较少数量的元素。因此,如果性能是一个问题,也许这是一个好主意。

于 2012-06-27T07:50:00.167 回答