金鹏

|| 叶落知秋,见微知著。|| 不出户,知天下﹔不窥牖,见天道。其出弥远,其知弥少。是以圣人不行而知,不见而明,不为而成。

博客园 首页 新随笔 联系 订阅 管理

问题:
你想在一个新的项目中使用,或在现有的项目上把非泛型的类型转换成它们的泛型表示。但是,你却不知道自己为什么想这样做,并且你也不知道哪些非泛型类型应该被转换成它们的泛型表示。

解决方法:

决定何时何地使用泛型,你需要考虑以下几件事:

<!--[if !supportLists]-->l         <!--[endif]-->你的类型将包含或者以多种不确定的数据类型来运行吗?如果是这样,那么创建一个泛型将比创建一个非泛型提供很多好处。如果你的类型将只以一种确定的类型运行,那么你就没必要去创建一个泛型了。

<!--[if !supportLists]-->l         <!--[endif]-->如果你的类型是值类型,那么就会发生装箱和拆箱操作,你应该考虑使用泛型去避免这些操作。

<!--[if !supportLists]-->l         <!--[endif]-->跟泛型关联的强类型检查会导致很快就检查到错误(比如在编译时,而不是在运行时),因此,缩短你的纠错周期。

<!--[if !supportLists]-->l         <!--[endif]-->随着你要写好几个类去处理不同的数据类型的运行(比如一个ArrayList只保存StreamReaders,而另一个则只保存StreamWriters),你的代码是否受到“臃肿”的困扰?泛型很容易做到只写一次代码,就可以实现运行每种类型进行工作。

<!--[if !supportLists]-->l         <!--[endif]-->泛型会得到非常清晰的代码。去除代码的臃肿,对你的类型强制使用强类型检查,你的代码会更容易阅读和理解。

讨论:

在大部分情况,你的代码都是适合使用泛型的。泛型会产生更高的代码重用,更好的性能,强类型检查和易读的代码。

 


今天看见一篇文章【C#食谱】【面食】菜单1: 何时何地使用泛型 ,总结的很好,我也总结一下,不过是反过来的:何时何地不能使用泛型。
注:以下未特别注明的话,均表示不能对外展现泛型,内部仍然可以使用泛型。
1、控件上,在控件上public一个泛型的属性,意味着窗体设计器无法打开。同样的,在重用的组件上也意味着不能打开设计器 了;
2、WebService上,据我目前所知,目前的WebService规范是不支持泛型的,不管是对外接口,还是返回/传入的数据类型;
3、COM的互操作,COM是不支持泛型的。

解决方案:
在以上的应用中,我们又如何避免泛型带来的麻烦呢?一般你可以:
1、包装泛型类,使其特例化,不再具有泛型的特征。例如:
public sealed class DependencyPropertyCollection : ReadonlyNamedCollection<DependencyProperty>
2、 定义非泛型的接口,将泛型的返回值或参数使用object方式访问,适合COM操作。

欢迎大家补充。

 

posted on 2008-01-28 10:27  金鹏  阅读(447)  评论(0编辑  收藏  举报