您好,登錄后才能下訂單哦!
這期內容當中小編將會給大家帶來有關怎么在Java項目中實現一個內置觀察者模式,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
主要使用到的Java API就兩個類:
Observer接口:觀察者對象,監聽被觀察者對象數據變化,一是數據發生變化 ,就做出相應地啥響應。
Observable類:被觀察者對象,提供添加及移出觀察者對像方法,數據發生喲完成時并通知所有已經添加進來的觀察者對象。
被觀察者代碼示例:
//Observable是被觀察者對象接口,實現該接口就是:目標(被觀察者)的具體實現 public class TargetObservable extends Observable { // 要觀察的數據:消息發生改變時,所有被添加的觀察者都能收到通知 private String message; public String getConent() { return message; } public void setMessage(String message) { this.message = message; // 被觀察者數據發生變化時,通過以下兩行代碼通知所有的觀察者 this.setChanged(); this.notifyObservers(message); } }
2個觀察者代碼示例:
//Observer對象是觀察者,實現Observer的對象就是具體的觀察者對象 public class TargetObserver implements Observer { // 定義觀察者名稱 private String name; public String getObserverName() { return name; } public void setObserverName(String observerName) { this.name = observerName; } @Override public void update(Observable arg0, Object arg1) { //更新消息數據 System.out.println(name + "收到了發生變化的數據內容是:" + ((TargetObservable) arg0).getConent()); } }
public class TargetObserver01 implements Observer { // 定義觀察者名稱 private String name01; public String getObserverName() { return name01; } public void setObserverName(String observerName) { this.name01 = observerName; } @Override public void update(Observable arg0, Object arg1) { //更新消息數據 System.out.println(name01 + "收到了發生變化的數據內容是:" + ((TargetObservable) arg0).getConent()); } }
測試代碼:
/** * @description:測試類 * @author ldm * @date 2016-11-1 上午8:29:07 */ public static void main(String[] args) { // 創建一個具體的被 觀察者 TargetObservable observable = new TargetObservable(); // 創建第一個觀察者 TargetObserver one = new TargetObserver(); one.setObserverName("我是觀察者A"); // 創建第二個觀察者 TargetObserver01 two = new TargetObserver01(); two.setObserverName("我是觀察者B"); // 注冊觀察者 observable.addObserver(one); observable.addObserver(two); // 目標更新天氣情況 observable.setMessage("***我要更新的數據***"); } }
執行結果:
我是觀察者B收到了發生變化的數據內容是:—–我要更新的數據—– 我是觀察者A收到了發生變化的數據內容是:—–我要更新的數據—–
模式優點:
一個被觀察者可以對應多個觀察者,當被觀察者發生變化的時候,他可以將消息通知給所有已經添加觀察者。基于接口實現為程序提供了更大的靈活性。
但在使用時要注意根據條件及時添加或移除觀察者對象,否則可能導致意料外結果 。
最后附上Observer和Observable的原碼,這樣我們自己在寫的時候就知道如何下手了:
package java.util; import java.util.Observable; public interface Observer { void update(Observable var1, Object var2); }
package java.util; import java.util.Observer; import java.util.Vector; public class Observable { private boolean changed = false; private Vector<Observer> obs = new Vector(); public Observable() { } public synchronized void addObserver(Observer var1) { if(var1 == null) { throw new NullPointerException(); } else { if(!this.obs.contains(var1)) { this.obs.addElement(var1); } } } public synchronized void deleteObserver(Observer var1) { this.obs.removeElement(var1); } public void notifyObservers() { this.notifyObservers((Object)null); } public void notifyObservers(Object var1) { Object[] var2; synchronized(this) { if(!this.changed) { return; } var2 = this.obs.toArray(); this.clearChanged(); } for(int var3 = var2.length - 1; var3 >= 0; --var3) { ((Observer)var2[var3]).update(this, var1); } } public synchronized void deleteObservers() { this.obs.removeAllElements(); } protected synchronized void setChanged() { this.changed = true; } protected synchronized void clearChanged() { this.changed = false; } public synchronized boolean hasChanged() { return this.changed; } public synchronized int countObservers() { return this.obs.size(); } }
上述就是小編為大家分享的怎么在Java項目中實現一個內置觀察者模式了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。