HeadFirst 设计模式 9迭代器与组合模式(餐厅合并)

迭代器模式

提供一种方法顺序访问一个聚合对象中的各个元素,而又不暴露其内部的表示。

迭代器模式让我们能够游走于聚合内的每个元素,而又不暴露其内部的表示。把游走的任务放在迭代器上,而不是聚合上。这样简化了聚合的接口和实现,也让责任各得其所。

集合collection/聚合aggregate:指一群对象,其存储方法可以是各式各样的数据结构,例如:列表、数组、散列表,无论用什么方式存储,一律可以视为是集合/聚合。

实例:

public class MenuItem{
  String name;
  String description;
  boolean vegetarian;
  double price;
  
  public MenuItem(String name,String description,boolean vegetarian,double price){
    this.name=name;
    this.description=description;
    this.vegetarian=vegetarian;
    this.price=price;
  }
  public String getName(){  return name;}
  public String getDescription(){   return description;}
  public double getprice(){   return price;}
  public boolean isVegetarian(){    return vegetarian;}
}

public interface Iterator{
  boolean hasNext();  //返回一个布尔值,判断是否还有更多的元素
  Object next();   //返回下一个元素
}

//实现迭代器接口  DinerMenu
public class DinerMenuIterator implements Iterator{
  MenuItem[] items;
  int position
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值