做系統設計的時候有時會碰到一些無法在父類(或者接口)中抽取通用行為的特性,遇到這種情況就可以采用StringConfigure模式,這個模式我取的名字,不知道是否已經有先人做了總結,如果哪位朋友知道這種模式的正確名稱,希望不吝賜教。
以JDBC中取得數據庫連接為例,我們可以抽象出數據庫的一些公共行為,比如連接數據庫都要求提供用戶名和密碼,因此在JDBC中提供設定連接的用戶名和密碼的方法。但是另外的一些行為則不一定是所有數據庫都具備的,比如對于網絡型數據庫才需要指定網絡地址,而文件型數據庫則不需要,再比如在MySQL中需要指定字符集,而其他數據庫則不一定需要。如果為了照顧這些特性,為JDBC提供setHostIP、setDBFilePath、setCharSet等方法的話無疑會使得接口變得復雜,會出現很多用不到的方法,并且這些方法也無法覆蓋所有未來可能出現的情況,比如某個數據庫又增加了允許用戶定制連接超時的方法,那么JDBC也要為他提供相應的setTimeOut方法。為了解決這個問題,JDBC提出了連接字符串的概念,這樣各個數據庫的JDBC驅動只要規定好連接字符串的格式即可,用戶把所有的配置信息寫到連接字符串中,如果用戶修改為其他數據庫的話只需修改連接字符串即可,不用修改其他的調用。
使用StringConfigure模式的好處是使得系統中的個性化配置在一個參數中完成,這樣保證系統的不同模塊的行為的一致性,缺點是配置字符串的格式要由各個實現模塊來規定,各個不同實現模塊的格式不一致,造成了一定的學習成本,而且無法在開發期發現配置字符串的問題。
這里再來講一個StringConfigure模式的應用的例子?,F在我們要開發一套對IC卡讀寫器的類庫,應用開發人員只要調用不同的IC卡讀寫子類即可實現操作不同的IC卡讀寫器。各種不同的IC卡讀寫器有兩個共同的抽象行為:讀卡和寫卡,即readCard和writeCard,但是各個不同的讀卡器還有自己的特性,比如有的讀卡器需要指定采用ISO格式還是IBM格式來讀寫磁卡,有的讀卡器需要指定讀寫操作的分隔符,這些特性不是各個讀寫器共有的,因此我們采用StringConfigure模式進行設計,開發如下的接口:
interface IICCarder
{
public void writeCard(String data);
public String readCard();
public void configure(String configStr);
}
比如需要指定讀寫格式的讀寫器就可以如下實現:
class SomeCarder implements IICarder
{
private FormatEnum format;
public void writeCard(String data)
{
if(format==FormatEnum.IBM)
{
.........
}
else...........
}
public String readCard()
{.............
}
public void configure(String configStr)
{
if(configStr.equls("IBM"))
{
format=FormatEnum.IBM
}
else if(configStr.equls("ISO"))
{
format=FormatEnum.ISO
}
}
}
開發人員使用的時候只要如下調用
IICarder c = new SomeCarder();
c.configure("IBM");
print c.readCard();
如果采用配置文件的話更可以把配置參數寫到配置文件中,這樣就可以避免修改代碼。