本篇內(nèi)容介紹了“怎么理解java觀察者模式”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)建站!專注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、微信小程序、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了東海免費(fèi)建站歡迎大家使用!
觀察者模式定義了對(duì)象間一對(duì)多的關(guān)系,讓一個(gè)或多個(gè)觀察者對(duì)象觀察一個(gè)主體對(duì)象。當(dāng)主體對(duì)象的狀態(tài)發(fā)生改變時(shí),系統(tǒng)能通知所有的依賴于此對(duì)象的觀察者,從而使得觀察者對(duì)象能夠自動(dòng)更新。
在觀察者模式中,被觀察的對(duì)象常常也被稱為目標(biāo)或主體(Subject),依賴的對(duì)象也被稱為觀察者(Observer)。下面以一個(gè)簡(jiǎn)單的實(shí)例來(lái)示范觀察者模式,程序先提供一個(gè)觀察者接口:
//觀察者接口 public interface Observer { public void update(Observable o, Object obj); }
上面Observer接口是一個(gè)觀察者接口,程序中所有觀察者都應(yīng)該實(shí)現(xiàn)該接口。在該接口的update()方法中包含了一個(gè)Observable類型的參數(shù),該參數(shù)代表被觀察的對(duì)象,也就是前面介紹的目標(biāo)或主題。此處Observable是一個(gè)抽象基類,程序中被觀察者應(yīng)該繼承該抽象類。下面是Observable抽象類的代碼:
//目標(biāo)對(duì)象的基類 public abstract class Observable { //用一個(gè)List來(lái)保存該對(duì)象上所有綁定的觀察者 List<Observer> observers = new ArrayList<Observer>(); //這個(gè)方法用于從該目標(biāo)對(duì)象上注冊(cè)觀察者 public void registObserver(Observer observer) { observers.add(observer); } //移出該對(duì)象上綁定的觀察者 public void removeObserver(Observer ovserver) { observers.remove(observer); } //通知該目標(biāo)對(duì)象上的所有觀察者 public void notifyObservers(Object value) { //遍歷觀察者集合,對(duì)每一個(gè)觀察者都進(jìn)行更新操作 for(Observer observer: observers) { observer.update(this, value); } } }
該Observer抽象類是所有被觀察者的基類,它主要提供了一個(gè)registObserver()方法用于注冊(cè)一個(gè)新的觀察者;并提供一個(gè)removeObserver()方法來(lái)移出一個(gè)已綁定的觀察者。當(dāng)具體被觀察對(duì)象的狀態(tài)發(fā)生改變時(shí)(比如setter方法中),會(huì)調(diào)用notifyObservers來(lái)通知所有觀察者。
下面是一個(gè)具體的目標(biāo)對(duì)象,該對(duì)象繼承了上面的Observable基類:
public class Product extends Observable { //定義兩個(gè)屬性 private String name; private double price; //無(wú)參構(gòu)造器 public Product() { } //帶參構(gòu)造器 pubilc Product(String name, double price) { this.name = name; this.price = price; } public String getName() { return name; } public double getPrice() { return price; } //當(dāng)Product的name屬性發(fā)生改變時(shí),程序會(huì)觸發(fā)該對(duì)象上注冊(cè)的所有觀察者 public void setName(String name) { this.name = name; notifyObservers(name); } //當(dāng)Product的price屬性發(fā)生改變時(shí),程序也會(huì)觸發(fā)該對(duì)象上注冊(cè)的所有觀察者 public void setPrice(double price) { this.price = price; notifyObservers(price); } }
正如程序中的代碼所示,當(dāng)程序調(diào)用Product的setName、setPrice方法來(lái)改變Product的name和price兩個(gè)屬性時(shí),這兩個(gè)方法將自動(dòng)觸發(fā)Observable基類的notifyObservers()方法。
接下來(lái)提供兩個(gè)觀察者,一個(gè)用于觀察Product的name屬性,另一個(gè)觀察Product的price屬性:
public class NameObserver implements Observer { //觀察者必須實(shí)現(xiàn)的update方法 @Override public void update(Observable o, Object obj) { if (obj instanceof String) { String name = (String)obj; System.out.println("NameObserver:" + o + ",Product的Name已改為" + name); } } }
PriceObserver.java:
public class PriceObserver implements Observer { //觀察者必須實(shí)現(xiàn)的update方法 @Override public void update(Observable o, Object obj) { if (obj instanceof Double) { double price = (Double)obj; System.out.println("PriceObserver:" + o + ",Product的Price已改為" + price); } } }
最后創(chuàng)建一個(gè)Product對(duì)象(即目標(biāo)對(duì)象),然后向該對(duì)象上綁定兩個(gè)觀察者:
public void Test { public static void main(String[] args) { //創(chuàng)建一個(gè)目標(biāo)對(duì)象 Product p = new Product("桌子", 34.56); //創(chuàng)建兩個(gè)觀察者 NameObserver nameObserver = new NameObserver(); PriceObserver priceObserver = new PriceObserver(); //將這兩個(gè)觀察者綁定到目標(biāo)對(duì)象上 p.registObserver(nameObserver); p.registObserver(priceObserver); //現(xiàn)在調(diào)用目標(biāo)對(duì)象的set方法來(lái)修改屬性值 p.setName("板凳"); p.setPrice(12.34); } }
運(yùn)行上面的程序,將可以看到當(dāng)Product的屬性值發(fā)生改變時(shí),注冊(cè)在該P(yáng)roduct上的NameObserver和PriceObserver將被觸發(fā)。
縱觀上面介紹的觀察者模式,我們發(fā)現(xiàn)它通常包含4個(gè)角色:
被觀察者(即目標(biāo)對(duì)象)抽象基類(即上面的Observable):它通常會(huì)持有多個(gè)觀察者對(duì)象的引用。Java提供了java.util.Observable基類來(lái)代表被觀察者的抽象基類,所以實(shí)際開(kāi)發(fā)中無(wú)需自己開(kāi)發(fā)這個(gè)角色
觀察者接口(即上面的Observer):該接口是所有被觀察對(duì)象應(yīng)該實(shí)現(xiàn)的接口,通常只包含一個(gè)抽象方法update。Java同樣提供了java.util.Observer接口來(lái)代表觀察者接口,所以實(shí)際開(kāi)發(fā)中也無(wú)需自己開(kāi)發(fā)這個(gè)角色
目標(biāo)對(duì)象的實(shí)現(xiàn)類(即上面的Product):該類繼承自O(shè)bservable基類
觀察者對(duì)象的實(shí)現(xiàn)類(即上面的NameObserver和PriceObserver):這些類實(shí)現(xiàn)Observer接口,實(shí)現(xiàn)update抽象方法
“怎么理解java觀察者模式”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!
本文標(biāo)題:怎么理解java觀察者模式
網(wǎng)站鏈接:http://bm7419.com/article16/phoigg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站設(shè)計(jì)、標(biāo)簽優(yōu)化、網(wǎng)站收錄、搜索引擎優(yōu)化、網(wǎng)站設(shè)計(jì)公司、網(wǎng)站排名
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)