论坛首页 Java企业应用论坛

设计模式之迭代器 Iterator

浏览 3454 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2007-01-16  
 

                                                                 表1.1  类,接口一览表

名称 说明
Aggregate 表示已聚合的接口
Iterator 执行递增,遍历的接口
Book 表示书籍的类
BookShelf 表示书架的类
BookShelfIterator 扫描书架的类
Main 测试用类
  这个程序是把书籍(Book)放到书架(BookShelf)上,并依次输出书名。

 

 

 

 

 

 Aggregate接口(Aggregate.java<o:p></o:p>
  1. public interface Aggregate {      
  2.   public abstract Iterator iterator();      
  3.  }    

Iterator 接口(Iterator.java<o:p></o:p>

  1. public interface Iterator {      
  2.    public abstract boolean hasNext();      
  3.    public abstract Object next();      
  4. }    
  Book类(Book.java <o:p></o:p>
  1. public class Book      
  2.  {      
  3.   private String name = "";      
  4.   public Book(String name) {      
  5.   this.name = name;      
  6.    }      
  7.    public String getName() {      
  8.    return name;      
  9.    }      
  10. }     

BookShelf类(BookShelf.java<o:p></o:p>

  1. public class BookShelf implements Aggregate {      
  2.   private Book[]  books;      
  3.   private int last = 0;      
  4.   public  BookShelf(int maxsize) {      
  5.      this.books = new  Book[maxsize];      
  6.    }      
  7.   public Book getBookAt(int index) {      
  8.     return books[index];      
  9.  }      
  10.  public  void appendBook(Book book) {      
  11.    this.books[last] = book ;      
  12.    last++;        
  13.   }      
  14.   public int getLength() {      
  15.    return new BookShelfIterator(this);      
  16.   }      
  17. }     
  18.   
BookShelfIterator类
  1. public class BookShelfIterator implaments Iterator {   
  2.   private BookShelf bookShelf;   
  3.   private int index;   
  4.   public BookShelfIterator (BookShelf boofShelf) {   
  5.      this.bookShelf = bookShelf;   
  6.      this.index = 0;   
  7.   }   
  8.   public  boolean hasNext () {   
  9.       if(index < bookShelf.getLength())  {   
  10.          return true;   
  11.        }else {   
  12.           return false;   
  13.        }   
  14.    }   
  15.    public  Object next () {   
  16.         Book book = bookShelf.getBookAt(index);   
  17.         index++;   
  18.          return book;   
  19.      }   
  20. }       
Main.java 测试类
  1. public class main{   
  2.   public static void main(String[] args) {   
  3.        BookShelf  bookShelf = new BookShelf(2);   
  4.        bookShelf.appendBook(new Book("Around  the  World  in 80 days"));   
  5.        bookShelf.appendBook(new Book("Bible"));   
  6.        Iterator it = bookShelf.iterator();   
  7.        while(it.hasNext()) {   
  8.           Book book = (Book)it.next();   
  9.           System.out.println(""+book.getName());   
  10.         }   
  11.   }   
  12. }  
   发表时间:2007-01-17  
在BoolShelf类中,如果书籍数量超过了最先设定的书架大小,就无法把书放上去了。如果利用java.util.Vector 取代数组,就能把程序改成即使已经超过了书架的承受数量,也能继续加书。
BookShelf.java
import java.util.Vector;
public class BookShelf implements Aggregate {
  private Vector books;
  public BookShelf(int initialsize) {
   this.books = new Vector(initialsize);
  }
  public Book getBookAt(int index) {
   return (Book)books.get(index);
  }
  public void appendBook(Book book) {
   books.add(book);
  }
  public int getLength() {
  return books.size();
  }
  public Iterator iterator() {
    return new BookShelfIterator(this);
 }
}

Main类
import java.util.*;
public class Main {
  public static void main(String[] args) {
    BookShelf bookShelf = new BookShelf(2);
    bookShelf.appendBook(new Book("Around the World in 80 days"));
    bookShelf.appendBook(new Book("Bible"));
    bookShelf.appendBook(new Book("Hello"));
    bookShelf.appendBook(new Book("Baby"));
    Iterator it = bookShelf.iterator();
    //while循环没变
    while(it.hasNext()) {
      Book book = (Book)it.next();
      System.out.println(""+book.getName());
   }
  }
}
1 请登录后投票
论坛首页 Java企业应用版

跳转论坛:
Global site tag (gtag.js) - Google Analytics