zoukankan      html  css  js  c++  java
  • 分部类(Partial Classes)

    C# 2.0 可以将类、结构或接口的定义拆分到两个或多个源文件中,在类声明前添加partial关键字即可。

    例如:下面的PartialTest

    class PartialTest

    {

    string Str_FieldTest;

    int Int_FieldTest;

    public void DoTest()

    {

    Debug.Print("Test");

    }

    }

    可在不同源文件中写成下面形式:

    一个文件中写:

    partial class PartialTest

    {

    string Str_FieldTest;

    int Int_FieldTest;

    }

    另一个文件中写:

    partial class PartialTest

    {

    public void DoTest()

    {

    Debug.Print("Test");

    }

    }

    什么情况下使用分部类?

            处理大型项目时,使一个类分布于多个独立文件中可以让多位程序员同时对该类进行处理(相当于支持并行处理,很实用);

            使用自动生成的源时,无需重新创建源文件便可将代码添加到类中。Visual Studio 在创建Windows 窗体、Web 窗体时都使用此方法。你不用编辑Visual Studio 所创建的文件,便可创建使用这些类的代码。换句话说:系统会自动创建一个文件(一般记录的是窗体及窗体中的控件的属性),另一个或几个文件记录的是用户自己编写的代码。这两部分分开可以使结构显得非常清晰,用户只需关注自己负责的那部分就行了(需要的话,这两部分可以互相调用)。等到了编辑运行的时候,系统会自动将这两部分合成一个文件。

    使用Partial需要注意以下一些情况

    1.      使用partial 关键字表明可在命名空间内定义该类、结构或接口的其他部分

    2.      所有部分都必须使用partial 关键字

    3.      各个部分必须具有相同的可访问性,如publicprivate

    4.      如果将任意部分声明为抽象的,则整个类型都被视为抽象的

    5.      如果将任意部分声明为密封的,则整个类型都被视为密封的

    6.      如果任意部分声明继承基类时,则整个类型都将继承该类

    7.      各个部分可以指定不同的基接口,最终类型将实现所有分部声明所列出的全部接口

    8.      在某一分部定义中声明的任何类、结构或接口成员可供所有其他部分使用

    9.嵌套类型可以是分部的,即使它们所嵌套于的类型本身并不是分部的也如此。如下所示:

    class Container

    {

      partial class Nested

     {

    void Test1();

    }

    partial class Nested

    {

     void Test2();

    }

    }

    使用分布类的一些限制:

     

    1.    要作为同一类型的各个部分的所有分部类型定义都必须使用partial 进行修饰。如下所示:

    public partial class A { }

    public class A { } // Error, must also be marked partial

    2.  partial 修饰符只能出现在紧靠关键字classstruct interface前面的位置(枚举或其它类型都不能使用partial);

    3.  要成为同一类型的各个部分的所有分部类型定义都必须在同一程序集和同一模块(.exe .dll 文件)中进行定义。分部定义不能跨越多个模块;

    4.  类名和泛型类型参数在所有的分部类型定义中都必须匹配。泛型类型可以是分部的。每个分部声明都必须以相同的顺序使用相同的参数名。

  • 相关阅读:
    字符串打印
    倒计时(二)之时间戳
    倒计时(一)之数字补0
    递增、递减运算符
    如何让background里的img图片自适应
    CSS三角图标(二)
    CSS三角图标(一)
    网易云外链接生成方法
    python基础语法一
    CSS固定菜单栏
  • 原文地址:https://www.cnblogs.com/hjtdlx/p/2220442.html
Copyright © 2011-2022 走看看