最近公司需要梳理开发规范,我负责写 扩展方法 这一部分。
所以特地写篇博文来准备一下。
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.注意扩展方法的数量和分类,数量较多时可考虑分类。例如 转换类型的扩展类,判断边界的扩展类。