Java 经典实例:自定义迭代器

企鹅博客
企鹅博客
企鹅博客
25193
文章
0
评论
2020年10月3日21:33:10 评论 7 views 1395字阅读4分39秒

编写自己的Iterator,实现Iterator接口,这里多说一句,实现Iterable后,可以用“foreach”循环遍历你的对象。

import Java.util.Iterator;
import java.util.NoSuchElementException;

/**
 * 演示Iterator和Iterable接口,并说明怎样编写一个用于对象数组的简单迭代器。
 */
public class AarrayIterator<T> implements Iterable<T>, Iterator<T> {
    private final static String[] names = {"rose", "petunia", "tulip"};

    public static void main(String[] args) {
        AarrayIterator<String> arrayIterator = new AarrayIterator<>(names);

        // Java 5,6的方式
        for (String s : arrayIterator) {
            System.out.println(s);
        }

        // Java 8的形式
        arrayIterator.forEach(System.out::println);
    }

    /**
    * 要遍历的数据
    **/
    protected T[] data;

    protected int index = 0;

    /**
    * 构造一个AarryIterator对象。
    *
    * @param data 被迭代的对象数组
    */
    public AarrayIterator(final T[] data) {
        setData(data);
    }

    /**
    * 设置(重置)数组为给定的数组,重置迭代器。
    * 参数d代表被迭代的数组对象。
    *
    * @param d 被迭代的数组对象
    */

    public void setData(final T[] d) {
        this.data = d;
        index = 0;
    }

    /**
    * 如果不是末尾,返回true,例如,if next()语句将成功执行。
    * 否则返回false,执行if next()语句会抛出异常。
    *
    * @return
    */
    public boolean hasNext() {
        return index < data.length;
    }

    /**
    * 返回该数据的下一个元素
    *
    * @return
    */
    public T next() {
        if (hasNext()) {
            return data[index++];
        }
        throw new NoSuchElementException("only " + data.length + " elements");
    }

    public void remove() {
        throw new UnsupportedOperationException("This demo Iterator does not implement the remove method");
    }

    /**
    * Iterator的方法
    *
    * @return
    */
    public Iterator<T> iterator() {
        index = 0;
        return this;
    }
}

执行结果:

继续阅读
Android短信应用——短信信息实时获取 Linux编程

Android短信应用——短信信息实时获取

我们知道,只需通过代码就可以读到收件箱中的短信,发件箱中的短信;但是却没办法在短信发来的瞬间获取;如果我们在短信发来的一瞬间能得到相应的信息内容,那么我们就可以依次来展开很多应用了——也就是通过短信去...
LRU缓存设计 Linux编程

LRU缓存设计

缓存的数据结构采用哈希表,key到value的映射。 网上有些资料采用记录数据的使用时刻 实现LRU策略,此处采用双向链表 实现LRU策略。LRU Least Recently Used,MRUMos...
R 语言 简单介绍 Linux编程

R 语言 简单介绍

一.统计分析软件说明  统计分析软件有:SPSS, SAS、R语言,Matlab,S-PLUS,S-Miner。 SPSS: 最简单的,都是菜单操作,不过不利于二次程序开发。 SAS: 需要...
匿名

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: