放弃重载,转而使用扩展方法

发布于 2024-10-30 22:04:12 字数 174 浏览 4 评论 0原文

既然我们在 C# 中有了扩展方法,那么在任何类的实现中保留重载以传递默认值还有什么意义吗? 当可以进行扩展方法重载时,为什么会污染类实现呢? 重载有什么好处(用于传递默认值)?

我正在计算默认参数的选项,因为它强制参数的特定顺序(即默认参数可以出现在最后),并且默认值在客户端代码中进行编译,并且服务包可能因此而中断。

Now that we have extension methods in C#, Is there any point left in keeping overloads in implementation of any class for passing default values?
Why pollute the class implementation when overloads can be made extension methods?
Any advantage of overloads (for passing default values)?

I'm counting out the option of default parameters because it forces specific ordering of parameters (i.e. default ones can come in end) and the fact that default value gets compiled in client code and a service pack could possibly break because of that.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

本王不退位尔等都是臣 2024-11-06 22:04:12

既然我们在 C# 中有了扩展方法,那么在任何类的实现中保留重载以传递默认值还有什么意义吗?

我将使用可选参数而不是扩展方法来删除重载。

扩展方法有很多缺点 - 它们对私有成员的访问较少,它们存在可发现性问题(因为它们是在单独的类上定义的)等。

但是,有时使用重载方法和构造函数比使用重载方法和构造函数更好添加可选参数 - 与您已经提到的问题分开。这包括:

  • 使用不理解可选参数的语言。 C# 和 VB.Net 并不是唯一的 .NET 语言。
  • 有时可选参数只是不能解决问题 - 例如,您经常需要一个真正的默认构造函数和可选参数,虽然它们在手动编写代码时看起来很像,但在面对反射/序列化等时表现得非常不同。

Now that we have extension methods in C#, Is there any point left in keeping overloads in implementation of any class for passing default values?

I would use optional arguments instead of extension methods to remove overloads.

Extension methods have quite a few disadvantages - they have less access to the private members, they have a discoverability issue (as they're defined on a separate class), etc.

However, there are times when using overloaded methods and constructors are better than adding optional arguments - separate from the issues you already mentioned. This include:

  • Working with languages which don't understand optional arguments. C# and VB.Net are not the only .NET languages out there.
  • Sometimes optional arguments just don't cut it - for example, you often need a true default constructor, and optional arguments, while they look like it when hand writing code, behave very differently in the face of reflection/serialization/etc.
九厘米的零° 2024-11-06 22:04:12

问题不应该是“重载有优势吗”,而应该是“扩展方法有哪些优势使其优于重载?”在我看来,扩展方法的缺点远远超过任何可察觉的优点。事实上,当您设计类时,我无法想出扩展方法提供的任何优势。

例如,假设您的类具有此方法:

public int Frob(int count)

但最常见的预期用例是客户端使用 count 值为 1 来调用它。因此您想要创建一个 Frob() 不需要该参数的方法。

当然,在 .NET 4.0 中,您可以使用默认参数来执行此操作,但正如您所说,默认参数并不总是一个选项,因为它们必须放在最后。因此,如果没有默认参数,您可以选择 1) 创建重载;或 2) 创建扩展方法。

创建过载很简单。创建扩展方法需要一个静态类和一个静态方法,并且引入了无意隐藏的可能性——所有的复杂性都没有任何好处。当您只需编写 dang 重载并完成它时,为什么要使用扩展方法来模拟重载呢?

如果您无法修改类,那么扩展方法是显而易见的选择。但如果可以选择,请使用旨在提供您想要的功能的功能。

The question shouldn't be "are there advantages to overloads," but rather, "what are the advantages of extension methods that make them superior to overloads?" In my opinion, the disadvantages of extension methods far outweigh any perceived advantages. In fact, I'm unable to come up with any advantage that extension methods provide when you're designing a class.

Suppose, for example, your class has this method:

public int Frob(int count)

But the most common expected use case is for clients to call it with a count value of 1. So you want to create a Frob() method that doesn't require that parameter.

Granted, in .NET 4.0 you could do this with default parameters, but as you say default parameters aren't always an option because they have to come last. So without default parameters, you have the option of 1) creating an overload; or 2) creating an extension method.

Creating an overload is straightforward. Creating an extension method requires a static class and a static method, and introduces the possibility of unintentional hiding--all complications that come with no benefit. Why use extension methods to emulate overloads when you can just write the dang overload and be done with it?

If you're unable to modify the class, then extension methods are the obvious choice. But given the choice, use the feature that's designed to provide the functionality that you want.

栀子花开つ 2024-11-06 22:04:12

除了 Reed Copsey 的答案:扩展方法根据定义是静态的,而静态通常被认为是邪恶的单元测试和模拟。这就是为什么我个人尝试尽可能避免扩展方法。

In addition to Reed Copsey's answer: extension methods are by definition static, and statics are often considered evil in terms of unit testing and mocking. This is why I personally try to avoid extension methods as much as possible.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文