【Java】Iterator底层原理,自己实现Iterator

package test;

import java.util.Iterator;

public class MyIterator implements java.lang.Iterable<String> {
	
	private String[] element = {"a","b","c","d","e"};
	
	private int size = element.length;
	
	//匿名内部类
	public Iterator<String> iterator(){
		return new Iterator<String>(){
			//游标指针
			private int cursor = -1;
			
			/**
			 * 判断是否存在下一个元素
			 * @return
			 */
			public boolean hasNext() {
				return cursor+1 < size;
			}
			
			/**
			 * 获取下一个元素
			 * @param args
			 */
			public String next() {
				cursor++;
				return element[cursor];
			}
			
			/**
			 * 删除元素
			 * @param args
			 */
			public void remove() {
				
			}
		};
	}
	
	public static void main(String[] args) {
		MyIterator test = new MyIterator();
		Iterator<String> it = test.iterator();
		
		while(it.hasNext()) {
			System.out.println(it.next());
		}
		
		//增强for,必须实现Iteralbe接口
		//不考虑下标
		for(String temp:test) {
			System.out.println(temp);
		}
	}
}

 

发布了35 篇原创文章 · 获赞 12 · 访问量 2万+
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 精致技术 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览