2023-04-01  阅读(2)
原文作者:LoveLion 原文地址:https://blog.csdn.net/lovelion/article/details/9992005

4 使用内部类实现迭代器

在迭代器模式结构图中,我们可以看到具体迭代器类和具体聚合类之间存在双重关系,其中一个关系为关联关系,在具体迭代器中需要维持一个对具体聚合对象的引用,该关联关系的目的是访问存储在聚合对象中的数据,以便迭代器能够对这些数据进行遍历操作。

除了使用关联关系外, 为了能够让迭代器可以访问到聚合对象中的数据 ,我们还 可以将迭代器类设计为聚合类的内部类 ,JDK中的迭代器类就是通过这种方法来实现的,如下AbstractList类代码片段所示:

    package java.util;
    ……
    public abstract class AbstractList<E> extends AbstractCollection<E> implements List<E> {
        ......
        private class Itr implements Iterator<E> {
    	    int cursor = 0;
            ......
    }
    ……
    }

我们可以通过类似的方法来设计第3节中的ProductList类,将ProductIterator类作为ProductList类的内部类,代码如下所示:

    //商品数据类:具体聚合类
    class ProductList extends AbstractObjectList {
    	public ProductList(List products) {
    		super(products);
    	}
    	
    	public AbstractIterator createIterator() {
    		return new ProductIterator();
    	}
    	
    	//商品迭代器:具体迭代器,内部类实现
    	private class ProductIterator implements AbstractIterator {
    		private int cursor1;
    		private int cursor2;
    		
    		public ProductIterator() {
    			cursor1 = 0;
    			cursor2 = objects.size() -1;
    		}
    		
    		public void next() {
    			if(cursor1 < objects.size()) {
    				cursor1++;
    			}
    		}
    		
    		public boolean isLast() {
    			return (cursor1 == objects.size());
    		}
    		
    		public void previous() {
    			if(cursor2 > -1) {
    				cursor2--;
    			}
    		}
    		
    		public boolean isFirst() {
    			return (cursor2 == -1);
    		}
    		
    		public Object getNextItem() {
    			return objects.get(cursor1);
    		} 
    			
    		public Object getPreviousItem() {
    			return objects.get(cursor2);
    		} 	
    	}
    }

无论使用哪种实现机制,客户端代码都是一样的,也就是说客户端无须关心具体迭代器对象的创建细节,只需通过调用工厂方法createIterator()即可得到一个可用的迭代器对象,这也是使用工厂方法模式的好处,通过工厂来封装对象的创建过程,简化了客户端的调用。


Java 面试宝典是大明哥全力打造的 Java 精品面试题,它是一份靠谱、强大、详细、经典的 Java 后端面试宝典。它不仅仅只是一道道面试题,而是一套完整的 Java 知识体系,一套你 Java 知识点的扫盲贴。

它的内容包括:

  • 大厂真题:Java 面试宝典里面的题目都是最近几年的高频的大厂面试真题。
  • 原创内容:Java 面试宝典内容全部都是大明哥原创,内容全面且通俗易懂,回答部分可以直接作为面试回答内容。
  • 持续更新:一次购买,永久有效。大明哥会持续更新 3+ 年,累计更新 1000+,宝典会不断迭代更新,保证最新、最全面。
  • 覆盖全面:本宝典累计更新 1000+,从 Java 入门到 Java 架构的高频面试题,实现 360° 全覆盖。
  • 不止面试:内容包含面试题解析、内容详解、知识扩展,它不仅仅只是一份面试题,更是一套完整的 Java 知识体系。
  • 宝典详情:https://www.yuque.com/chenssy/sike-java/xvlo920axlp7sf4k
  • 宝典总览:https://www.yuque.com/chenssy/sike-java/yogsehzntzgp4ly1
  • 宝典进展:https://www.yuque.com/chenssy/sike-java/en9ned7loo47z5aw

目前 Java 面试宝典累计更新 400+ 道,总字数 42w+。大明哥还在持续更新中,下图是大明哥在 2024-12 月份的更新情况:

想了解详情的小伙伴,扫描下面二维码加大明哥微信【daming091】咨询

同时,大明哥也整理一套目前市面最常见的热点面试题。微信搜[大明哥聊 Java]或扫描下方二维码关注大明哥的原创公众号[大明哥聊 Java] ,回复【面试题】 即可免费领取。

阅读全文