设计模式的应用场景(22)--迭代器模式

迭代器模式是一种设计模式,它允许顺序访问聚合对象的元素而不暴露其内部结构。在Java中,List和Map等容器已内置迭代器支持,方便开发者进行遍历操作。这种模式将遍历行为从聚合对象中分离出来,提高了代码的灵活性和封装性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

迭代器模式

定义:提供了一种顺序访问一个聚合对象中各元素而又不暴露该对象内部结构的方法。

优点:分离了集合对象的遍历行为,抽象出一个迭代器类来负责。

缺点:仅适用于访问容器。

Java一些容器已经实现了迭代器模式,例如List,Map

好吧,我们直接使用,不再自己生产了。

import java.util.List;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.Map;
import java.util.HashMap;
import java.util.Set;

public class Client {
    public static void main(String[] argv) {
        List list = new ArrayList();
		list.add("张三");
        list.add("李四");
        list.add("王五");
		Iterator iter = list.iterator();
   		while(iter.hasNext()) {
   			 System.out.println(iter.next());
  		}
   		Map map = new HashMap();
        map.put("1", "张三");
        map.put("2", "李四");
        map.put("3", "王五");
		Set s = map.entrySet();
  	    iter = s.iterator();
  	    while(iter.hasNext()) {
    		Map.Entry me = (Map.Entry)iter.next();
    		String key = (String)me.getKey();
    		String value = (String)me.getValue();
    		System.out.println("key = "+key+", value = "+value);
   		}
    }  
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值