`
wangpx
  • 浏览: 202338 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

Iterator patten 读书笔记

阅读更多
提供 一种方法 顺序访问 一个聚和 对象中的各个元素,而又不暴露其内部的表示或实现。
迭代器模式让我们能游走于聚合内的每一个元素,而又不暴露其内部的表示。把游走的任务放在迭代器上,而不是聚合上。这样简化了聚合的接口和实现,也让责任各得其所。
1.迭代器允许访问聚合的元素,而不需要暴露它的内部结构。
2.迭代器将遍历聚合的工作封装进一个对象中。
3.当使用迭代器的时候,我们依赖聚合提供遍历。
4.迭代器提供了一个通用的接口,让我们遍历聚合项,当我们编码使用聚合的项时,就可以使用多太机制。

package pattern;
import java.util.ArrayList;
import java.util.Calendar;
import com.sun.org.apache.xalan.internal.xsltc.runtime.Hashtable;
public class MenuTestDrive {
 public static void main(String[] args) {
  PancakeHouseMenu pancakeHouseMenu = new PancakeHouseMenu();
  DinerMenu dinerMenu = new DinerMenu();
  CafeMenu cafeMenu = new CafeMenu();
  Waitress waitress = new Waitress(pancakeHouseMenu, dinerMenu,cafeMenu);
  waitress.printMenu();
 }
}
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 boolean isVegetarian() {
  return vegetarian;
 }
 public double getPrice() {
  return price;
 }
}
interface Menu{
 public Iterator creatIterator();
}
class PancakeHouseMenu implements Menu {
 ArrayList<MenuItem> menuItems=new ArrayList<MenuItem>();
 public PancakeHouseMenu() {
  menuItems = new ArrayList<MenuItem>();
  addItem("K&B'S Pancake Breakfast",
    "Pancakes with scrambled eggs,and toast", true, 2.99);
  addItem("Regular Pancake Breakfast",
    "Pancakes with fried eggs,and sausage", true, 2.99);
  addItem("BlueBerry Pancakes ", "Pancakes made with fresh blueberries",
    true, 3.49);
  addItem("Waffles",
    "Waffles with your choice of blueberries or strawberries",
    true, 3.59);
 }
 public void addItem(String name, String description, boolean vegetarian,
   double price) {
  MenuItem menuItem = new MenuItem(name, description, vegetarian, price);
  menuItems.add(menuItem);
 }
 public Iterator creatIterator() {
  return new PancakeHouseMenuIterator(menuItems);
 }
}
class DinerMenu implements Menu{
 static final int MAX_ITEMS = 6;
 int numberOfItems = 0;
 MenuItem[] menuItems= new MenuItem[MAX_ITEMS];
 public DinerMenu() {  
  addItem("Vegetarian BLT",
    "(Fakin') Bacon with lettuce & tomato on whole wheat", true,
    2.99);
  addItem("BLT", " Bacon with lettuce & tomato on whole wheat", true,
    2.99);
  addItem("Soup of the day",
    "Soup of the day,with a side of potato salad", true, 2.99);
  addItem("Hotdog",
    "A hot dog, with saurkraut,relish,onions,topped with cheese",
    true, 2.99);
 }
 public void addItem(String name, String description, boolean vegetarian,
   double price) {
  MenuItem menuItem = new MenuItem(name, description, vegetarian, price);
  if (numberOfItems >= MAX_ITEMS) {
   System.err.println("Sorry menu is full ,can not add item to menu!");
  } else {
   menuItems[numberOfItems] = menuItem;
   numberOfItems = numberOfItems + 1;
  }
 }
 public Iterator creatIterator() {
  return new DinerMenuIterator(menuItems);
 }
}
class CafeMenu implements Menu{
 Hashtable menuItems=new Hashtable();
 int position=0;
 public CafeMenu(){
  addItem("Vegegie Burger and Air Fries",
    "Veggie burger on a whole wheat bun,lettuce,tomato,and fries", true,
    3.99);
  addItem("Soup of the day", "A cup of the soup of the day,with a side salad", true,
    2.99);
  addItem("Burrito",
    "A large burrito , with whole pinto beans,salsa,guacamole", true, 2.99);
  
 }
 public void addItem(String name, String description, boolean vegetarian,
   double price) {
  MenuItem menuItem = new MenuItem(name, description, vegetarian, price);
  menuItems.put(position, menuItem);
  position++;
 }
 public Iterator creatIterator() {
  return new CafeMenuIterator(menuItems);
 }
}
interface Iterator {
 boolean hasNext();
 Object next();
 void remove(int i);
}
class DinerMenuIterator implements Iterator {
 MenuItem[] items;
 int position = 0;
 public DinerMenuIterator(MenuItem[] items) {
  this.items = items;
 }
 public boolean hasNext() {
  if (position >= items.length || items[position] == null) {
   return false;
  } else
   return true;
 }
 public Object next() {
  MenuItem menuItem = items[position];
  position = position + 1;
  return menuItem;
 }
 public void remove(int i){
  if(i>=items.length || items[i] == null){
   System.err.println("err");
  }else{
   for(int n=i;n<items.length-1;n++){
    items[n]=items[n+1];
   }
  }
 }
}
 class PancakeHouseMenuIterator implements Iterator {
 ArrayList<MenuItem> items;
 int position = 0;
 public PancakeHouseMenuIterator(ArrayList<MenuItem> items) {
  this.items = items;
 }
 public boolean hasNext() {
  if (position >= items.size()) {
   return false;
  } else
   return true;
 }
 public Object next() {
  MenuItem menuItem = (MenuItem) items.get(position);
  position = position + 1;
  return menuItem;
 }
 @Override
 public void remove(int i) {
  items.remove(i);
 } 
}
 class CafeMenuIterator implements Iterator {
  Hashtable items;  
  int position = 0;
  public CafeMenuIterator(Hashtable items) {
   this.items = items;
  }
  public boolean hasNext() {
   if (position >= items.size()) {
    return false;
   } else
    return true;
  }
  public Object next() {
   MenuItem menuItem = (MenuItem) items.get(position);
   position++;
   return menuItem;
  }
  @Override
  public void remove(int i) {
   items.remove(i);
  } 
 }
 
class AlternatingDinerMenuIterator implements Iterator{
 MenuItem[] items;
 int position;
 public  AlternatingDinerMenuIterator(MenuItem[] items){
  this.items=items;
  Calendar rightNow=Calendar.getInstance();
  position =rightNow.get(Calendar.DAY_OF_WEEK)%2;
 }
 public boolean hasNext(){
  if(position>=items.length||items[position]==null){
   return false;
  }else{
   return true;
  }
 }
 public Object next(){
  MenuItem menuItem=items[position];
  position=position+2;
  return menuItem;
 }
 public void remove(int i){
  throw new UnsupportedOperationException("Alternating Diner Menu Iterator does not support remove()");
 }
}
class Waitress {
 Menu pancakeHouseMenu;
 Menu dinerMenu;
 CafeMenu cafeMenu;
 public Waitress(Menu pancakeHouseMenu, Menu dinerMenu,CafeMenu cafeMenu) {
  this.pancakeHouseMenu = pancakeHouseMenu;
  this.dinerMenu = dinerMenu;
  this.cafeMenu= cafeMenu;
 }
 public void printMenu() {
  Iterator PancakeHouseMenuIterator = pancakeHouseMenu
    .creatIterator();
  Iterator dinerMenuIterator = dinerMenu.creatIterator();
  Iterator  cafeMenuIterator=cafeMenu.creatIterator();
  System.out.println("MENU\n------\nBREAKFAST");
  printMenu(PancakeHouseMenuIterator);
  System.out.println("\nLUNCH");
  printMenu(dinerMenuIterator);
  System.out.println("\nDINNER");
  printMenu(cafeMenuIterator);
 }
 private void printMenu(Iterator iterator) {
  while (iterator.hasNext()) {
   MenuItem menuItem = (MenuItem) iterator.next();
   System.out.print(menuItem.getName() + ",");
   System.out.print(menuItem.getPrice() + "--");
   System.out.println(menuItem.getDescription());
  }
 }
}
分享到:
评论

相关推荐

    良葛格DesignPattern学习笔记

    良葛格的《Design Pattern学习笔记》不仅涵盖了经典的GOF设计模式,还额外介绍了几种多线程模式,这使得这份学习笔记成为了一个宝贵的学习资源。下面将对其中的部分设计模式进行详细介绍。 #### 二、GOF设计模式 ...

    300Java设计模式部分学习笔记

    2. 迭代器模式(Iterator Pattern):提供一种方法顺序访问一个聚合对象中的各个元素,而又不暴露该对象的内部表示。 3. 中介者模式(Mediator Pattern):用一个中介对象来封装一系列的对象交互。 4. 命令模式...

    Gof design pattern 中文/英文版+web+学习笔记

    15. **迭代器模式(Iterator)**:提供一种方法顺序访问聚合对象的元素,而又不暴露其底层表示。 16. **访问者模式(Visitor)**:表示一个作用于某对象结构中的各元素的操作。它使你可以在不改变各元素的类的前提...

    设计模式整理代码-pattern.zip

    - 迭代器模式(Iterator):提供一种方法顺序访问聚合对象的元素,而又不暴露其底层表示。 - 中介者模式(Mediator):定义一个中介对象来简化原本复杂的对象交互。 - 观察者模式(Observer):定义对象之间的一...

    Java_se基础毕向东老师全程笔记

    - **迭代器**:使用`Iterator`或增强型for循环遍历集合。 ### 第八章:IO流 - **输入输出流**:`InputStream`、`OutputStream`。 - **文件操作**:读写文件、文件复制等。 - **缓冲区流**:使用`BufferedReader`、`...

    java设计模式笔记_行为模式借鉴.pdf

    备忘录模式通常与其他设计模式结合使用,如命令模式(Command Pattern)和迭代器模式(Iterator Pattern)。在命令模式中,备忘录可以用来存储命令执行前的状态,以便在需要时撤销操作。在迭代器模式中,备忘录可以...

    Java JDK 7学习笔记(国内第一本Java 7,前期版本累计销量5万册)

    9.1.5 访问对象的iterator 273 9.1.6 排序收集的对象 276 9.1.7 使用泛型 280 9.2 键值对应的map 284 9.2.1 常用map操作类 284 9.2.2 访问map键值 288 9.3 重点复习 291 9.4 课后练习 292 chapter10...

    DesignPattern:设计模式的学习笔记和示例代码

    设计模式是软件工程中的一种最佳实践,它是在特定情境下解决常见问题的经验总结。...在DesignPattern-master这个压缩包中,你可以找到关于这些模式的详细讲解和实例代码,为你的Java开发之旅提供宝贵的参考资料。

    Struts2.1学习笔记

    ### Struts2.1学习笔记 #### Struts2的来源与优点 - **来源**:Struts2是在WebWork2的基础上发展起来的,它继承了WebWork2的优点,并且进行了改进,使其更适合现代Web应用程序的需求。与Struts1相比,Struts2的...

    JAVA学习笔记第十三天示例代码

    在具体使用Collection接口时,我们还可以使用`iterator()`获取迭代器,通过迭代器遍历集合。另外,`clear()`方法可以清空集合,`isEmpty()`检查集合是否为空,`toArray()`则可以将集合转换为数组。对于多线程环境,...

    23中设计模式学习笔记.docx

    ### 23种设计模式学习笔记 #### 一、软件设计模式的概念与意义 **概念:** 软件设计模式(Software Design Pattern),又称设计模式,是一套被广泛采用、经过整理和分类的代码设计经验总结。它针对软件设计过程中...

Global site tag (gtag.js) - Google Analytics