.NET 3.5扩展方法的优点与限制有哪些,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
.NET 3.5扩展方法:新增的语言特性
原本,我听说 Partial Class 的时候,以为可以为已存在的类添加方法了,不过,Partial Class 只能在同一个 Assembly 之中的要求,使得它并不能实现这一点。.Net 3.5 增加了很多语言特性,扩展方法是其中一个。用扩展方法,我们就可以为已经存在的类添加方法。
public static class ExtendTest { public static Print(this object o) { Console.WriteLine(o); } }
之后,就可以对于任意的 object 使用这个方法:
string s = "hello"; s.Print(); "X".Print(); MyClass x = new MyClass(); x.Print();
.NET 3.5扩展方法的创建
对于扩展方法的创建,基本上,只有两点记住就可以了:必须是静态方法,***个参数增加 this 关键字。
用 Reflector 查看了一下,和我的猜测基本一致,其实它的实现是使用的自定义属性,所以扩展方法基本上可以看成是编译器特性:
public static class ExtendTest { [ Extend ] public static Print(object o) { Console.WriteLine(o); } }
扩展方法很好用,使用上确实可以和动态语言像 Python、Ruby 之类的相比了。不过,毕竟 C# 是静态语言,扩展方法还是有一些限制的。
.NET 3.5扩展方法的限制
一个限制是:不能使用原有类的私有或保护成员。这个问题,怎么说呢,大部分情况下没有问题,不过如果真的想使用私有或保护成员的时候,会很头疼。如果要给 .Net framework 中的类添加方法,这个问题也许并不是太大吧,毕竟一般我们也只知道它们的公有成员。如果要给自己的 DLL 添加一个新的 DLL,也做到原有 DLL 用于 .Net 2.0,新 DLL 扩展原 DLL 的话,比较会遇到。我在 DbEntry.Net 中对于这个问题的解决方案是,使用友元程序集。这种方法还是需要修改原 DLL,添加新 DLL 为友元程序集,另外,将需要访问的成员标注为 internal 才行。
另一个限制:不能给一个类添加静态方法。不知道是不是我没有找到,反正感觉,本来就是静态方法了,怎么才能再标注为实现静态方法呢?难道用 static static ?当然,使用的场景应该也不多吧。
再一个限制:不能给一个类添加接口。这个么,本来就不是扩展方法的设计目标,而且,实现上似乎也会麻烦很多,所以本来不该抱怨,不过,如果能实现的话,确实会有很多地方会很方便。比如,如果能给 DbObjectModel 添加 IQueryable 接口,就可以只通过增加一个 using 而实现所有的 Linq 功能,而有这个限制的时候,只能再实现一个 LinqDbObjectModel 之类的了……
关于.NET 3.5扩展方法的优点与限制有哪些问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网行业资讯频道了解更多相关知识。