观察者模式(Observer)--迭代器模式(Iterator)

本文深入探讨了观察者模式和迭代器模式在软件设计中的应用。观察者模式通过建立一对多的依赖关系,使得当一个对象状态改变时,所有依赖于它的对象都能得到通知并自动更新。迭代器模式则提供了一种访问聚合对象中元素的方法,而不暴露其底层的表示。两种模式都避免了类间的紧耦合,提高了系统的灵活性。

15、观察者模式(Observer)

包括这个模式在内的接下来的四个模式,都是类和类之间的关系,不涉及到继承

当你订阅了该文章,如果后续有更新,会及时通知你。对象之间是一种一对多的关系。

MySubject类就是被观察者。

public interface Observer {  

    public void update();  

}  

public class Observer1 implements Observer {  

    @Override  

    public void update() {  

        System.out.println("observer1 has received!");  

    }  

}  

public class Observer2 implements Observer {  

    @Override  

    public void update() {  

        System.out.println("observer2 has received!");  

    }  

}  

public interface Subject {  

    /*增加观察者*/  

    public void add(Observer observer);  

    /*删除观察者*/  

    public void del(Observer observer);  

    /*通知所有的观察者*/  

    public void notifyObservers();  

    /*自身的操作*/  

    public void operation();  

}  

public abstract class AbstractSubject implements Subject {  

    private Vector<Observer> vector = new Vector<Observer>();  

    @Override  

    public void add(Observer observer) {  

        vector.add(observer);  

    }  

    @Override  

    public void del(Observer observer) {  

        vector.remove(observer);  

    }  

    @Override  

    public void notifyObservers() {  

        Enumeration<Observer> enumo = vector.elements();  

        while(enumo.hasMoreElements()){  

            enumo.nextElement().update();  

        }  

    }  

}  

public class MySubject extends AbstractSubject {  

    @Override  

    public void operation() {  

        System.out.println("update self!");  

        notifyObservers();  

    }  

}  

public class ObserverTest {  

    public static void main(String[] args) {  

        Subject sub = new MySubject();  

        sub.add(new Observer1());  

        sub.add(new Observer2());  

        sub.operation();  

    }  

}  

16、迭代模式(Iterator)

迭代器模式就是顺序访问聚集中的对象

public interface Collection {  

    public Iterator iterator();  

    /*取得集合元素*/  

    public Object get(int i);  

    /*取得集合大小*/  

    public int size();  

}  

public interface Iterator {  

    //前移  

    public Object previous();  

    //后移  

    public Object next();  

    public boolean hasNext();  

    //取得第一个元素  

    public Object first();  

}  

public class MyCollection implements Collection {  

    public String string[] = {"A","B","C","D","E"};  

    @Override  

    public Iterator iterator() {  

        return new MyIterator(this);  

    }  

    @Override  

    public Object get(int i) {  

        return string[i];  

    }  

    @Override  

    public int size() {  

        return string.length;  

    }  

}  

public class MyIterator implements Iterator {  

    private Collection collection;  

    private int pos = -1;  

    public MyIterator(Collection collection){  

        this.collection = collection;  

    }  

    @Override  

    public Object previous() {  

        if(pos > 0){  

            pos--;  

        }  

        return collection.get(pos);  

    }  

    @Override  

    public Object next() {  

        if(pos<collection.size()-1){  

            pos++;  

        }  

        return collection.get(pos);  

    }  

    @Override  

    public boolean hasNext() {  

        return pos<collection.size()-1; 

    }  

    @Override  

    public Object first() {  

        pos = 0;  

        return collection.get(pos);  

    }  

}  

public class Test {  

    public static void main(String[] args) {  

        Collection collection = new MyCollection();  

        Iterator it = collection.iterator();  

        while(it.hasNext()){  

            System.out.println(it.next());  

        }  

    }  

}  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值