C# 扩展方法

最近公司需要梳理开发规范,我负责写 扩展方法 这一部分。

所以特地写篇博文来准备一下。

MSDN:  https://docs.microsoft.com/zh-cn/dotnet/csharp/programming-guide/classes-and-structs/extension-methods

https://www.cnblogs.com/pengze0902/p/6110094.html

https://www.cnblogs.com/Matcha/archive/2016/03/31/5312288.html

特别基础的,怎么实现怎么调用,就不说了,着重看一下有哪些特殊的地方。

我对扩展类命名的习惯是类命名为原类名加上 Ex 后缀,Ex 代表的是 Extension 扩展。

可以使用扩展方法来扩展类或接口,但不能重写扩展方法。与接口或类方法具有相同名称和签名的扩展方法永远不会被调用(即扩展方法不会覆盖类中原有的方法,这也是一个风险)。

编译时,扩展方法的优先级总是比类型本身中定义的实例方法低。

使用场景:

1.一般大家都会写一个 Util/Common/xxxHelper 之类的的工具类,里面会有 例如 StringHelper、DateTimeHelper 等等,每个Helper里面有多个static的通用方法,然后调用的时候就是StringHelper.GetNotNullStr("aa"); 这样。还有一种普通的用法就是new 一个对象,通过对象去调用类里面的非static方法。这通常来说意味着一串的代码,这个时候如果我们适当的使用扩展方法来写这些方法,调用就会简短很多,例如 "aa".GetNotNullStr(); 。

2.一般来说我们在开发的过程中,总会需要调用第三方类库,或是使用一些我们没有权限修改的类,这时候使用扩展方法就是一个不错的选择,但若第三方类库或原有类添加了同名方法,那么扩展方法就会被覆盖。

3.可以使用扩展方法来实现 链式调用。例如 LINQ。

优点:

1.使代码变得更加简洁,调用简单。

2.不会破坏原有类的封装性,只有引入了扩展方法命名空间的才可以使用。

缺点:

1.存在被覆盖的可能。

关于扩展方法的一些建议:

1.注意对扩展目标的把控,对 List<T> 所做的扩展 是否可以改为对 IList<T> 或 IEnumerable<T>.

2.注意扩展方法的数量和分类,数量较多时可考虑分类。例如 转换类型的扩展类,判断边界的扩展类。



转载请标明出处

作者:AaXuan

地址:http://www.cnblogs.com/Aaxuan

知识共享许可协议

本作品采用  知识共享署名 3.0 未本地化版本许可协议  进行许可。

原文地址:https://www.cnblogs.com/Aaxuan/p/9740440.html