Java深入到一定程度,就不可避免的碰到設計模式(design pattern)這一概念,了解設計模式,將使自己對java中的接口或抽象類應用有更深的理解。設計模式在java的中型系統中應用廣泛,遵循一定的編程模式,才能使自己的代碼便於理解,易於交流,Observer(觀察者)模式是比較常用的一個模式,尤其在界面設計中應用廣泛,而本教程所關注的是Java在電子商務系統中應用,因此想從電子商務實例中分析Observer的應用。
雖然網上商店形式多樣,每個站點有自己的特色,但也有其一般的共性,單就"商品的變化,以便及時通知訂戶"這一點,是很多網上商店共有的模式,這一模式類似Observer patern。
具體的說,如果網上商店中商品在名稱 價格等方面有變化,如果系統能自動通知會員,將是網上商店區別傳統商店的一大特色。這就需要在商品product中加入Observer這樣角色,以便product細節發生變化時,Observer能自動觀察到這種變化,並能進行及時的update或notify動作。
Java的API還為為我們提供現成的Observer接口Java.util.Observer。我們只要直接使用它就可以。
我們必須extends Java.util.Observer才能真正使用它:
我們注意到,在product類中 的setXXX方法中,我們設置了 notify(通知)方法,當Jsp表單調用setXXX,實際上就觸發了notisfyObservers方法,這將通知相應觀察者應該采取行動了。
下面看看這些觀察者的代碼,他們究竟采取了什么行動:
Jsp中我們可以來正式執行這段觀察者程序:
雖然網上商店形式多樣,每個站點有自己的特色,但也有其一般的共性,單就"商品的變化,以便及時通知訂戶"這一點,是很多網上商店共有的模式,這一模式類似Observer patern。
具體的說,如果網上商店中商品在名稱 價格等方面有變化,如果系統能自動通知會員,將是網上商店區別傳統商店的一大特色。這就需要在商品product中加入Observer這樣角色,以便product細節發生變化時,Observer能自動觀察到這種變化,並能進行及時的update或notify動作。

Java的API還為為我們提供現成的Observer接口Java.util.Observer。我們只要直接使用它就可以。
我們必須extends Java.util.Observer才能真正使用它:
- 提供Add/Delete observer的方法;
- 提供通知(notisfy) 所有observer的方法。
1 //產品類 可供Jsp直接使用UseBean調用 該類主要執行產品數據庫插入 更新 2 public class product extends Observable{ 3 private String name; 4 private float price; 5 public String getName(){ return name;} 6 public void setName(){ 7 this.name=name; 8 //設置變化點 9 setChanged(); 10 notifyObservers(name); 11 } 12 public float getPrice(){ return price;} 13 public void setPrice(){ 14 this.price=price; 15 //設置變化點 16 setChanged(); 17 notifyObservers(new Float(price)); 18 } 19 //以下可以是數據庫更新 插入命令. 20 public void saveToDb(){ 21 ..................... 22 } 23 }
下面看看這些觀察者的代碼,他們究竟采取了什么行動:
1 //觀察者NameObserver主要用來對產品名稱(name)進行觀察的 2 public class NameObserver implements Observer{ 3 private String name=null; 4 public void update(Observable obj,Object arg){ 5 if (arg instanceof String){ 6 name=(String)arg; 7 //產品名稱改變值在name中 8 System.out.println("NameObserver :name changet to "+name); 9 } 10 } 11 } 12 13 //觀察者PriceObserver主要用來對產品價格(price)進行觀察的 14 public class PriceObserver implements Observer{ 15 private float price=0; 16 public void update(Observable obj,Object arg){ 17 if (arg instanceof Float){ 18 price=((Float)arg).floatValue(); 19 System.out.println("PriceObserver :price changet to "+price); 20 } 21 } 22 }
1 <jsp:useBean id="product" scope="session" class="Product" /> 2 <jsp:setProperty name="product" property="*" /> 3 4 <jsp:useBean id="nameobs" scope="session" class="NameObserver" /> 5 <jsp:setProperty name="product" property="*" /> 6 7 <jsp:useBean id="priceobs" scope="session" class="PriceObserver" /> 8 <jsp:setProperty name="product" property="*" /> 9 10 <% 11 if (request.getParameter("save")!=null) 12 { 13 product.saveToDb(); 14 out.println("產品數據變動 保存! 並已經自動通知客戶"); 15 }else{ 16 //加入觀察者 17 product.addObserver(nameobs); 18 product.addObserver(priceobs); 19 %> 20 //request.getRequestURI()是產生本jsp的程序名,就是自己調用自己 21 <form action="<%=request.getRequestURI()%>" method=post> 22 <input type=hidden name="save" value="1"> 23 產品名稱:<input type=text name="name" > 24 產品價格:<input type=text name="price"> 25 <input type=submit> 26 </form> 27 <% 28 } 29 %>
執行改Jsp程序,會出現一個表單錄入界面,需要輸入產品名稱 產品價格,點按Submit后,還是執行該jsp的if (request.getParameter("save")!=null)之間的代碼。
由於這里使用了數據javabeans的自動賦值概念,實際程序自動執行了setName setPrice語句。你會在服務器控制台中發現下面信息:
1 NameObserver :name changet to ?????(Jsp表單中輸入的產品名稱) 2 PriceObserver :price changet to ???(Jsp表單中輸入的產品價格);
這說明觀察者已經在行動了。
同時你會在執行jsp的瀏覽器端得到信息:
產品數據變動 保存! 並已經自動通知客戶
上文由於使用jsp概念,隱含很多自動動作,現將調用觀察者的Java代碼寫如下:
1 public class Test { 2 public static void main(String args[]){ 3 Product product=new Product(); 4 NameObserver nameobs=new NameObserver(); 5 PriceObserver priceobs=new PriceObserver(); 6 7 //加入觀察者 8 product.addObserver(nameobs); 9 product.addObserver(priceobs); 10 11 product.setName("橘子紅了"); 12 product.setPrice(9.22f); 13 } 14 }
你會在發現下面信息:
PriceObserver :price changet to 9.22
這說明觀察者在行動了。
系列文章:
Java設計模式(5)共享模式/享元模式(Flyweight模式)
Java設計模式(14)責任鏈模式(Chain of Responsibility模式)