当前位置:   article > 正文

C#部分方法有什么用处?和传统方法有什么区别?什么时候用合适?

C#部分方法有什么用处?和传统方法有什么区别?什么时候用合适?

在C#中,部分类(partial class)和部分方法(partial method)是两个不同的概念,但它们经常一起使用,特别是在代码生成和框架设计中。下面我将分别解释这两个概念,并讨论它们的用处、与传统方法的区别以及何时使用它们。

部分类(Partial Class)

用处:

当一个类被定义在多个文件中时,可以使用partial关键字来分割这个类。这允许自动生成的代码(如由设计器生成的代码)与用户编写的代码分开,但又能组合成一个完整的类。
在某些情况下,将类分割到多个文件中可以提高代码的可读性和可维护性。
与传统类的区别:

传统类必须完全定义在一个文件中。而部分类可以在多个文件中定义,只要这些文件的命名空间、类名和访问修饰符都相同,并且都使用了partial关键字。
何时使用:

当使用如Windows Forms设计器或WPF设计器等工具时,这些工具会自动生成部分类的代码。此时,你可以在一个单独的文件中编写与用户界面相关的逻辑,而不需要修改自动生成的代码。
当你想要将大型类分割到多个文件中以提高可读性时。

部分方法(Partial Method)

C#中的部分方法(Partial Methods)提供了一种在编译时确定是否要包含方法实现的机制。它们主要用于代码生成场景,特别是当自动生成代码需要与用户定义的代码交互时。

用处

代码生成与扩展性:在如ASP.NET MVC、Windows Forms或WPF等框架中,设计器经常生成部分类的代码。使用部分方法,设计器可以定义一个方法签名,但只有在用户提供的代码中实际实现了该方法时,它才会被调用。这为用户提供了扩展自动生成代码的能力,而无需修改设计器生成的代码。
可选的回调:在框架或库中,部分方法可以用作可选的回调点。基类或接口可以定义一个部分方法,而实现类可以选择是否提供实现。这提供了一种灵活的方式来定义可选的行为。
减少模板代码:在代码生成场景中,部分方法可以减少生成的模板代码量。设计器可以生成一个部分方法作为占位符,而不是生成一个完整的空方法或抛出异常的方法。

与传统方法的区别

实现的可选性:传统方法必须在定义时提供实现,或者在派生类中通过重写(override)来提供自定义实现。而部分方法允许在基类或接口中定义一个没有实现的方法签名,只有在派生类或实现类中提供了实现时,该方法才会被调用。
访问修饰符和修饰符:部分方法必须是私有的(private),并且不能有访问修饰符或任何修饰符(如static、virtual、abstract等)。而传统方法可以有各种访问修饰符和修饰符。
返回类型和参数:部分方法不能有返回类型(除了void),并且不能有out参数。这些限制确保了部分方法主要用于简单的回调和扩展点,而不是作为主要的业务逻辑。

什么时候用合适

代码生成场景:当使用设计器或代码生成工具时,部分方法可以用于定义用户可以在不修改自动生成代码的情况下扩展的点。
框架和库设计:在设计框架或库时,部分方法可以用作可选的回调点,允许用户在不修改框架代码的情况下提供自定义行为。
减少模板代码:当需要生成大量模板代码时,部分方法可以用作占位符,减少生成的代码量。
需要注意的是,由于部分方法的限制(如必须是私有的、不能有返回类型等),它们通常不是用于实现主要业务逻辑的首选方法。相反,它们更适用于作为扩展点、回调或代码生成场景中的占位符。

当设计一个框架或库时,你想要为使用者提供一些可选的扩展点,但又不想强制他们实现这些方法。通过使用部分方法,你可以定义一个方法签名,并在需要时由使用者提供实现。
当你想要在不修改基类代码的情况下,为现有类添加新功能时。你可以通过继承该类并为一个部分方法提供实现来添加新功能,而无需修改基类的任何代码。

需要注意的是,部分方法有一些限制:

它们必须是私有的。
它们不能有访问修饰符或任何修饰符(如static、virtual、abstract等)。
它们不能有返回类型(除了void)。
它们不能有out参数。
只有在定义部分方法的同一部分类或同一文件的其他部分类中,才能为该部分方法提供实现。

public  partial class ClassTest
{
    // 声明一个partial method 可以是空的,其他部分类实现,如果未实现当前调用无任何执行 
    partial void MyPartialMethod();
    public void Start()
    {
        Console.WriteLine("start1执行");
        MyPartialMethod();
        Console.WriteLine("start1执行完成");
    }
  
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/正经夜光杯/article/detail/748578
推荐阅读