.NET 框架中的 Factory 模式
Factory 模式是一种非常基本同时也是被广泛使用的设计模式, 我在这里就不多说了,这种模式在框架程序设
计中经常被采用,今天就说一下在.NET 框架下的一个使用例子。
首先请大家看一下如下代码段:
int iCount = System.Text.Encoding.Default.GetByteCount(calStr.Trim()); ..... byte[] b = Encoding.Default.GetBytes(str); ..... Encoding encode = Encoding.GetEncoding(this.FileEncode); .....
相信大家对于这样的代码司空见惯了吧, 本人也是在使用很长一段时间之后,才对里面的实现方式发生兴趣的,
在了解了基本的算法逻辑后,发现这个名Encoding这个抽象类的部分代码是使用 Factory 模式实现的。
为了清楚说明这个问题,本人将Factory 模式的基本结构图先发上来,另外本人还附一张相应的.net Encoding
实现的结构图,以便大家对比参照:
Factory 图
.net Encoding 结构图
这里需要说明的是Factory 结构图中的SimpleFactory部分在Encoding 代码中被合并了,原因我猜应该是为了方便调用
和维护。如果把GetEncoding() 拿出来放到SimpleFactory中,也只是“搬个家”而已。另外就是封装到了Encoding中同样也
会出现工厂模式所不可回避的问题就是如果新增加一种编码怎么办?让我们看看微软所做的一些"尝试":
在GetEncoding(Int32)函数里的switch 有如下代码
switch (codepage) { ....... default: unicode = GetEncodingCodePage(codepage); if (unicode == null) { unicode = GetEncodingRare(codepage); //当编码很少见时 } break; }
......
在GetEncodingRare里面有一些少见编码的实例化调用,具体的声明我就不多说了,大家可以用
Reflactor 到 mscorlib 下的System.Text.Encoding.GetEncodingRare(int codepage)函数即可, 看到里
面的还有一些没有实现的case 条件段大家就应该明白了。而有关codepage 设置参见
http://www.cppblog.com/shenhuafeng/archive/2007/04/05/21336.html
另外就是框架本身更新的速度还是非常快的(微软可能在将来某个版本中改动这部分的代码,但目前.net3.0
框架下未发生变化)。当然解决新加编码的方式不止一种,有人建议用反射,也有说用“factory method”的,这
里就不多做介绍了。(例如:http://blog.csdn.net/linzhisong/archive/2007/07/13/1687887.aspx)
还有一个地方就是如下对属性的声明
private static Encoding asciiEncoding; public static Encoding UTF8; ......
基本上对框架中主要的编码都有声明。目前根据我的理解只是为了方便使用才这样安排的。