欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

详解java迭代器模式

时间:2020-12-14 14:13:24|栏目:JAVA代码|点击:

场景

  1. 提供一种可以遍历聚合对象的方式。又称为:游标cursor模式
  2. 聚合对象:存储数据
  3. 迭代器:遍历数据

JDK内置的迭代器(List/Set)

package com.qianyu.gof.iterator;

import java.util.ArrayList;
import java.util.Iterator;

/**
 * @author lijing
 * @date 2019-04-10-14:38
 * @discroption JDK内置迭代器测试类
 */
public class IteratorTest {
  public static void main(String[] args) {
    ArrayList<String> list = new ArrayList<String>();
    list.add("a");
    list.add("b");
    list.add("c");
    Iterator<String> iter = list.iterator();
    //hasNext()判断是否有下一个元素
    while (iter.hasNext()) {
      //next()函数返回当前元素,并将游标指向下一位
      System.out.println(iter.next());
    }
  }
}

手动实现迭代器

package com.qianyu.gof.iterator;

/**
 * @author lijing
 * @date 2019-04-10-14:37
 * @discroption 迭代器接口
 */
public interface MyIterator {
  /**
   * 判断是否有下一个元素
   *
   * @return
   */
  boolean hasNext();

  /**
   * 返回当前元素,并且将游标向下移动一位
   *
   * @return
   */
  Object next();
}
package com.qianyu.gof.iterator;

import java.util.ArrayList;
import java.util.List;

/**
 * @author lijing
 * @date 2019-04-10-19:18
 * @discroption 自定义聚合类
 */
public class MyList {
  List<Object> list = new ArrayList<Object>();

  public boolean add(Object obj) {
    return list.add(obj);
  }

  public boolean remove(Object obj) {
    return list.remove(obj);
  }

  /**
   * 返回迭代器对象
   *
   * @return
   */
  public ConcreteIterator iterator() {
    return new ConcreteIterator();
  }

  /**
   * 自定义内部类,可以直接使用外部类的属性
   */
  private class ConcreteIterator implements MyIterator {
    //游标
    private int cursor = 0;

    @Override
    public boolean hasNext() {
      return this.cursor < list.size();
    }

    @Override
    public Object next() {
      return list.get(cursor++);
    }
  }
}
package com.qianyu.gof.iterator;

/**
 * @author lijing
 * @date 2019-04-10-19:14
 * @discroption 自定义迭代器测试类(迭代器模式)
 */
public class IteratorTest2 {
  public static void main(String[] args) {
    MyList myList = new MyList();
    myList.add("aa");
    myList.add("bb");
    myList.add("cc");
    MyIterator iter = myList.iterator();
    while (iter.hasNext()){
      System.out.println(iter.next());
    }
  }
}

UML类图:

上一篇:Eclipse配置tomcat发布路径的问题wtpwebapps解决办法

栏    目:JAVA代码

下一篇:JAVA 数据结构之Queue处理实例代码

本文标题:详解java迭代器模式

本文地址:http://www.codeinn.net/misctech/32534.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有