模式與重構
設計模式總結-Visitor模式
摘要: Visitor模式的一個優(yōu)點體現(xiàn)在對集合元素的訪問中:由于集合中的可訪問元素都實現(xiàn)了Visitable接口,所以在迭代集合的過程中,我們可以將每個元素都看成是接口類型。
其次由于JAVA語言的多態(tài)性,雖然每個元素都是接口類型(Visitable),但每個元素的實現(xiàn)類不同,所以在調用accept方法時,虛擬機“知道”應該調起那個正確的方法(例如:集合中的一個String元素,會調用StringElement的accept方法) 閱讀全文
其次由于JAVA語言的多態(tài)性,雖然每個元素都是接口類型(Visitable),但每個元素的實現(xiàn)類不同,所以在調用accept方法時,虛擬機“知道”應該調起那個正確的方法(例如:集合中的一個String元素,會調用StringElement的accept方法) 閱讀全文
設計模式總結-Strategy模式
摘要: 策略操作定義了策略的輸入和輸出,而把策略的實現(xiàn)工作留給了各個類。這些類以不同的方案來實現(xiàn)同一操作,它們?yōu)橛脩籼峁┙y(tǒng)一的接口,因而這些類可以相互替換。
Strategy模式允許多種策略共存,而代碼不會混亂。策略模式也可以實現(xiàn)模式選擇邏輯和策略本身相分離。
Strategy模式的意圖在于把可選的策略或方案封裝在不同的類中,并在這些類中實現(xiàn)一個共同的操作。 閱讀全文
Strategy模式允許多種策略共存,而代碼不會混亂。策略模式也可以實現(xiàn)模式選擇邏輯和策略本身相分離。
Strategy模式的意圖在于把可選的策略或方案封裝在不同的類中,并在這些類中實現(xiàn)一個共同的操作。 閱讀全文
設計模式總結-State模式
摘要: 使用狀態(tài)模式后,客戶端外界可以直接使用事件Event實現(xiàn),根本不必關心該事件導致如何狀態(tài)變化,這些是由狀態(tài)機等內部實現(xiàn)。這是一種Event-condition-State,狀態(tài)模式封裝了condition-State部分。
每個狀態(tài)形成一個子類,每個狀態(tài)只關心它的下一個可能狀態(tài),從而無形中形成了狀態(tài)轉換的規(guī)則。如果新的狀態(tài)加入,只涉及它的前一個狀態(tài)修改和定義。 閱讀全文
每個狀態(tài)形成一個子類,每個狀態(tài)只關心它的下一個可能狀態(tài),從而無形中形成了狀態(tài)轉換的規(guī)則。如果新的狀態(tài)加入,只涉及它的前一個狀態(tài)修改和定義。 閱讀全文
設計模式總結-Command模式
摘要: 讓方法運行最常見的方式是調用之,但是在很多情況下,我們不能控制和提供方法執(zhí)行的上下文和時機。這種情況下,可以把方法封裝在對象中。通過在對象中存儲調用方法所需的信息,就可以讓客戶端或者服務決定何時調用這個方法。
Command模式的意圖是把請求封裝在對象中。
--摘自《Java設計模式》第24章:Command(命令)模式
閱讀全文
Command模式的意圖是把請求封裝在對象中。
--摘自《Java設計模式》第24章:Command(命令)模式
閱讀全文
設計模式總結-Memento模式(二)
摘要: Memento模式和其它模式的結合應用:
一、“Mementor”模式和“堆?!钡慕Y合-“GUI界面撤銷功能”的實現(xiàn)
二、“Mementor”模式和“Observer”模式的結合-“通知式恢復”
三、“Mementor”模式和“Observer”模式、“責任鏈”模式的結合-“鏈式通知恢復”
四、“Mementor”模式和“Flyweight”模式的結合:減少相同對象的拷貝 閱讀全文
一、“Mementor”模式和“堆?!钡慕Y合-“GUI界面撤銷功能”的實現(xiàn)
二、“Mementor”模式和“Observer”模式的結合-“通知式恢復”
三、“Mementor”模式和“Observer”模式、“責任鏈”模式的結合-“鏈式通知恢復”
四、“Mementor”模式和“Flyweight”模式的結合:減少相同對象的拷貝 閱讀全文
設計模式總結-Memento模式(一)
摘要: Memento模式的特點:
在需要提供保存、恢復對象狀態(tài)的類中,必須提供兩個方法:
.保存對象當前狀態(tài)方法:將對象自身(this)作為參數(shù)傳入,創(chuàng)建備忘錄。
.恢復對象之前狀態(tài)的方法:取出備忘錄/接收一個備忘錄對象,從中獲取對象之前的狀態(tài)
模式的缺點是耗費大,如果內部狀態(tài)很多,再保存一份,無意要浪費大量內存.
注意:Memento模式保存的是操作前對象的狀態(tài),而不是操作后對象的狀態(tài);否則就沒辦法做恢復了 閱讀全文
在需要提供保存、恢復對象狀態(tài)的類中,必須提供兩個方法:
.保存對象當前狀態(tài)方法:將對象自身(this)作為參數(shù)傳入,創(chuàng)建備忘錄。
.恢復對象之前狀態(tài)的方法:取出備忘錄/接收一個備忘錄對象,從中獲取對象之前的狀態(tài)
模式的缺點是耗費大,如果內部狀態(tài)很多,再保存一份,無意要浪費大量內存.
注意:Memento模式保存的是操作前對象的狀態(tài),而不是操作后對象的狀態(tài);否則就沒辦法做恢復了 閱讀全文
設計模式總結-Observer模式
摘要: 下面是Observer模式的實現(xiàn)過程:
·創(chuàng)建一個被觀察者,繼承java.util.Observable
·創(chuàng)建一個觀察者,實現(xiàn)java.util.Observer接口
·注冊觀察著,調用addObserver(Observer observer)
·在被觀察者改變對象內部狀態(tài)的地方,調用setChanged()方法,然后調用notifyObservers(Object)方法,通知被觀察者
·在觀察者的update(Object)方法中,對改變做出響應。 閱讀全文
·創(chuàng)建一個被觀察者,繼承java.util.Observable
·創(chuàng)建一個觀察者,實現(xiàn)java.util.Observer接口
·注冊觀察著,調用addObserver(Observer observer)
·在被觀察者改變對象內部狀態(tài)的地方,調用setChanged()方法,然后調用notifyObservers(Object)方法,通知被觀察者
·在觀察者的update(Object)方法中,對改變做出響應。 閱讀全文
設計模式總結-Flyweight模式
摘要: Flyweight模式一般由幾個部分組成:
·Flyweight接口(抽象類) :定義了一個可共享的元類
·Flyweight實現(xiàn)類:實現(xiàn)了元類中的操作,而且可能會提供一個用于保存內部狀態(tài)(共享屬性)的空間
·Flyweight Factory:創(chuàng)建Flyweight的工廠類,創(chuàng)建后將其保存到Flyweight Pool中
·Flyweight Pool:緩沖Flyweight對象的池,通常包含在工廠類中 閱讀全文
·Flyweight接口(抽象類) :定義了一個可共享的元類
·Flyweight實現(xiàn)類:實現(xiàn)了元類中的操作,而且可能會提供一個用于保存內部狀態(tài)(共享屬性)的空間
·Flyweight Factory:創(chuàng)建Flyweight的工廠類,創(chuàng)建后將其保存到Flyweight Pool中
·Flyweight Pool:緩沖Flyweight對象的池,通常包含在工廠類中 閱讀全文
設計模式總結-Bridge模式
摘要: ·在抽象接口中包含了一個對行為接口的引用,這樣的話行為的操作將完全委托給行為接口完成,抽象類無需關心。
·在抽象類的繼承子類中,調用了行為類的子類來實現(xiàn)不同的行為。此時抽象類的子類中只知道屬性,但不知道具體的行為實現(xiàn),實現(xiàn)了概念與行為的分離
·在行為類的繼承子類中,只知道執(zhí)行相應的動作,但不知道具體的屬性,實現(xiàn)了行為和概念的分離 閱讀全文
·在抽象類的繼承子類中,調用了行為類的子類來實現(xiàn)不同的行為。此時抽象類的子類中只知道屬性,但不知道具體的行為實現(xiàn),實現(xiàn)了概念與行為的分離
·在行為類的繼承子類中,只知道執(zhí)行相應的動作,但不知道具體的屬性,實現(xiàn)了行為和概念的分離 閱讀全文
設計模式總結-Decorator模式(二)
摘要: Decorator模式的實際應用--動態(tài)黑名單過濾 閱讀全文
設計模式總結-Decorator模式
摘要: Decrator模式的適用場合:
1).在運行時刻由用戶動態(tài)決定加入的方式和時機,無法在編譯期間決定
2).需要改變的行為太多,用繼承會導致復雜性的增加 閱讀全文
1).在運行時刻由用戶動態(tài)決定加入的方式和時機,無法在編譯期間決定
2).需要改變的行為太多,用繼承會導致復雜性的增加 閱讀全文
設計模式總結-Composite模式(一)
摘要: Composite模式的特點:
·Composite模式一般都有一個抽象類或接口來表示最基本的構件。
·Composite模式一般都由兩類對象構成:表示單個元素的對象(Primitive)和表示多個元素組合的對象(Composite)
·Composite模式下Primitive和Composite對象都繼承或實現(xiàn)上層接口或父類
·Composite模式下每個構件都含有三個基礎方法:add(構件)、remove(構件)、iterator()
·Composite對象含有一個用來保存其下所有基礎元素的的集合,例如:Vector,ArrayList,HashMap
·Composite對象的方法被調用時一般都會引起其下所有基礎元素相同方法的調用,即遞歸調用。 閱讀全文
·Composite模式一般都有一個抽象類或接口來表示最基本的構件。
·Composite模式一般都由兩類對象構成:表示單個元素的對象(Primitive)和表示多個元素組合的對象(Composite)
·Composite模式下Primitive和Composite對象都繼承或實現(xiàn)上層接口或父類
·Composite模式下每個構件都含有三個基礎方法:add(構件)、remove(構件)、iterator()
·Composite對象含有一個用來保存其下所有基礎元素的的集合,例如:Vector,ArrayList,HashMap
·Composite對象的方法被調用時一般都會引起其下所有基礎元素相同方法的調用,即遞歸調用。 閱讀全文
設計模式總結-Adapter模式
摘要: 從上面的四種方式來看,方式二最簡單也最常用,方式三最靈活,方式一和四有相同的地方就是都繼承了其中的某一個類,這樣就限制了適配器的子類不能再繼承其它的功能父類了,不同的地方是方式一使用委托的方式來完成類B的功能,而方式四則自己實現(xiàn)了接口的方法。 閱讀全文
設計模式總結-Proxy模式
摘要: Proxy類具有幾個特點
·Proxy類一般都實現(xiàn)或繼承了后臺對象接口或抽象類,在其中實現(xiàn)了后臺對象接口的方法,這樣外界和代理類打交道的客戶端看到的是和后臺對象一樣的接口。根本不知道自己在和代理對象打交道。
·Proxy類一般都含有一個后臺對象作為其成員,因為代理類需要在其實現(xiàn)接口的方法中調用后臺對象的真正方法來實現(xiàn)業(yè)務邏輯。
·Proxy類一般都需要包含一個能夠驗證用戶請求是否合法的對象,如上例中的ForumPermisssions類,作為轉發(fā)或拒絕用戶請求的判斷依據(jù) 閱讀全文
·Proxy類一般都實現(xiàn)或繼承了后臺對象接口或抽象類,在其中實現(xiàn)了后臺對象接口的方法,這樣外界和代理類打交道的客戶端看到的是和后臺對象一樣的接口。根本不知道自己在和代理對象打交道。
·Proxy類一般都含有一個后臺對象作為其成員,因為代理類需要在其實現(xiàn)接口的方法中調用后臺對象的真正方法來實現(xiàn)業(yè)務邏輯。
·Proxy類一般都需要包含一個能夠驗證用戶請求是否合法的對象,如上例中的ForumPermisssions類,作為轉發(fā)或拒絕用戶請求的判斷依據(jù) 閱讀全文
設計模式總結-單例模式
摘要: 在多線程環(huán)境下,我們無法保證一個方法能夠持續(xù)運行到結束,其他線程的方法才開始運行。因而可能存在這樣一種情形:兩個線程幾乎同時嘗試初始化單例類。假設第一個方法發(fā)現(xiàn)單例為空,而第二個方法在此刻開始運行,它也會發(fā)現(xiàn)該單例為空。接下來,這兩個方法都將對該單例進行初始化 閱讀全文
| |||||||||
日 | 一 | 二 | 三 | 四 | 五 | 六 | |||
---|---|---|---|---|---|---|---|---|---|
25 | 26 | 27 | 28 | 29 | 30 | 31 | |||
1 | 2 | 3 | 4 | 5 | 6 | 7 | |||
8 | 9 | 10 | 11 | 12 | 13 | 14 | |||
15 | 16 | 17 | 18 | 19 | 20 | 21 | |||
22 | 23 | 24 | 25 | 26 | 27 | 28 | |||
29 | 30 | 1 | 2 | 3 | 4 | 5 |
常用鏈接
留言簿(21)
隨筆分類
- J2EE 框架(9)
- J2EE基礎(4)
- J2SE(43)
- Java 工具(5)
- Oracle Concept(4)
- Oracle SQL/PLSQL(9)
- Oracle 開發(fā)(13)
- Oracle 管理(4)
- Oracle 調優(yōu)
- Oracle 錯誤診斷
- RoR(19)
- UML(3)
- Unix / Linux(13)
- Web基礎(19)
- 其它技術(7)
- 感悟(3)
- 雜項(7)
- 架構與性能(8)
- 模式與重構(19)
- 灌水(8)
- 電影與音樂(16)
- 走過的路(1)
- 軟件過程與軟件方法(3)
- 陽光戶外(2)
- 項目管理(36)
隨筆檔案
- 2012年2月 (3)
- 2011年11月 (4)
- 2011年10月 (1)
- 2011年9月 (2)
- 2011年8月 (2)
- 2011年7月 (5)
- 2011年6月 (3)
- 2011年5月 (1)
- 2011年4月 (1)
- 2011年3月 (3)
- 2011年1月 (1)
- 2010年12月 (1)
- 2010年11月 (5)
- 2010年10月 (3)
- 2010年9月 (1)
- 2010年7月 (1)
- 2010年6月 (1)
- 2010年5月 (4)
- 2010年4月 (9)
- 2010年3月 (19)
- 2010年2月 (8)
- 2010年1月 (3)
- 2009年12月 (34)
- 2009年11月 (1)
- 2009年10月 (2)
- 2009年7月 (4)
- 2009年6月 (5)
- 2009年5月 (3)
- 2009年4月 (2)
- 2009年3月 (1)
- 2009年2月 (5)
- 2009年1月 (5)
- 2008年12月 (13)
- 2008年11月 (4)
- 2008年10月 (1)
- 2008年9月 (6)
- 2008年8月 (5)
- 2008年7月 (3)
- 2008年6月 (31)
- 2008年5月 (10)
- 2008年4月 (9)
- 2008年3月 (7)
- 2008年2月 (4)
- 2008年1月 (19)
BlogJava熱點博客
好友博客
搜索
最新評論

- 1.?re: 【Java基礎專題】編碼與亂碼(01)---編碼基礎[未登錄]
- 666666666666666666666這幾天正在做個類似工程編碼出現(xiàn)錯誤
- --李
- 2.?re: 【Java基礎專題】IO與文件讀寫---使用Apache commons IO簡化文件讀寫
- 不錯
- --阿斯蘭
- 3.?re: 【Java基礎專題】編碼與亂碼(03)----String的toCharArray()方法
- 多謝分享
- --thx
- 4.?re: 【Java基礎專題】編碼與亂碼(05)---GBK與UTF-8之間的轉換
- 評論內容較長,點擊標題查看
- --karl
- 5.?re: 【Java基礎專題】編碼與亂碼(01)---編碼基礎[未登錄]
- 謝謝,幫了我大忙!
- --小龍