C 抽象工廠模式的幾種實現方法及比較

2021-04-29 16:13:36 字數 1996 閱讀 7320

利用設計模式可以使我們的**更靈活,更容易擴充套件,更容易維護。各種物件導向的程式語言都提供了基本相同的機制:比如類、繼承、派生、多型等等。但是又有各自的特色,c# 中的反射機制便是乙個很重要的工具,好好地利用就可以在實際中發揮很大的作用。

我們來看乙個例子:

哦,我們都看設計模式,聽吧,很多人都在那裡鼓吹他們是如何如何的棒,我們看看怎麼樣利用他們來解決問題。目標明確了,那我們看看哪個能夠符合我們的要求。gof的《設計模式》都看過吧,似懂非懂的看了一些,那我們看看能夠不能夠「湊」上去呢?j 嗯,我們的程式考慮的是物件怎麼建立的,建立型模式應該符合要求吧。然後我們瀏覽一下各模式的「意圖」部分。呵呵,第乙個好像就撞到彩了,抽象工廠,我們看看吧,「提供乙個建立一系列相關或相互依賴物件的介面,而無需指定它們具體的類」,至少「無需指定它們具體的類」符合我們的要求。來看看它的結構吧:

下面的一些東西顯然是我們需要的:

public inte***ce ifruit

public class orange:ifruit }

} 我們的fruitfactory應該是怎麼樣呢?上面的結構圖中它給的是createproducta,那好,我就makeorange,還有乙個createproductb,俺makeorange還不行??

public class fruitfactory }

怎麼使用這個工廠呢?我們來寫下面的**:

string fruitname = console.readline(); ifruit myfruit = null;

fruitfactory myfruitfactory = new fruitfactory();

switch (fruitname)

編譯執行,然後在控制台輸入想要的東西,呵呵,成功了。沉浸在幸福中的你得意忘形了吧。

不過等等,它好像還不完美,我如果想要pear,我既要在客戶**中的switch中加入判斷,又要在工廠方法中加入makepear方法,好像不怎麼優雅。更好一點,在工廠中只提供乙個方法,makefruit,然後傳遞進乙個引數name,代表我們想要的水果的名稱,這樣的話,似乎我們的客戶**中的那個switch就可以不要了,相反,在fruitfactory中好像需要乙個,還等什麼呢?實現吧。

fruitfactory: public class fruitfactory }

} 客戶**:

string fruitname = console.readline(); ifruit myfruit;

fruitfactory myfruitfactory = new fruitfactory();

myfruit = myfruitfactory.makefruit(fruitname);

這樣看起來好多了,至少我客戶**中不要再寫那麼一長串的判斷**了。

阿q精神又在起作用,我們又沉浸在成功的喜悅中了。 嗯,**好像可以,應該沒有什麼改進了。但是好像又有另外乙個聲音在說:

「除了一點……」

「嗯? 等等,什麼?」

「fruitfactory也有switch啊,看起來也ugly啊!」

「哼,肯定是看《重構》或者是《tdd》了,怎麼要求那麼苛刻!反正閒著也是閒著,看看可以改不?」

另外乙個重要的類就是system.activator,它包含特定的方法,用以在本地或從遠端建立物件型別,或獲取對現有遠端物件的引用。

我們可以先利用type類獲取name指定的類名的類的type資訊,然後可以根據這個資訊利用activator建立物件。還等什麼呢?

public class fruitfactory

catch (typeloadexception e)

console.writeline("i dont know this kind of fruit,exception caught - " ,e.message);

return myfruit;

} }

經過這樣的處理以後,增加新的水果的時候,我們不需要修改客戶**了,同時工廠的**也不需要修改了,怎麼樣,爽吧!

C 抽象工廠模式的幾種實現方法及比較

利用設計模式可以使我們的 更靈活,更容易擴充套件,更容易維護。各種 物件導向的程式語言都提供了基本相同的機制 比如類 繼承 派生 多型等等。但是又有各自的特色,c 中的反射機制便是乙個很重要的工具,好好地利用就可以在實際中發揮很大的作用。我們來看乙個例子 哦,我們都看設計模式,聽吧,很多人都在那裡鼓...

C 抽象工廠模式的幾種實現方法及比較

利用設計模式可以使我們的 更靈活,更容易擴充套件,更容易維護。各種物件導向的程式語言都提供了基本相同的機制 比如類 繼承 派生 多型等等。但是又有各自的特色,c 中的反射機制便是乙個很重要的工具,好好地利用就可以在實際中發揮很大的作用 我們來看乙個例子 下面的一些東西顯然是我們需要的 public ...

C 抽象工廠模式的幾種實現方法及比較

利用設計模式能夠使我們的 更靈活,更容易擴充套件,更容易維護。各種物件導向的程式語言都提供了基本相同的機制 比如類 繼承 派生 多型等等。但是又有各自的特色,c 中的反射機制便是個很重要的工具,好好地利用就能夠在實際中發揮很大的作用。我們來看乙個例子 哦,我們都看設計模式,聽吧,很多人都在那裡鼓吹他...