分部类重温篇[好处,示例]

 1今天一大早我打开组员的代码,突然感觉有必要用partial了,所以再重温一下。
 2
 3partial:
 4   
 5   可以将类、结构或接口的定义拆分到两个或多个源文件中。每个源文件包含类定义的一部分,编译应用程序时将把所有部分组合起来。在以下几种情况下需要拆分类定义:
 6   处理大型项目时,使一个类分布于多个独立文件中可以让多位程序员同时对该类进行处理。
 7   若要拆分类定义,请使用 partial 关键字修饰符,如下所示:
 8public partial class Employee
 9{
10    public void DoWork()
11    {
12    }

13}

14
15public partial class Employee
16{
17    public void GoToLunch()
18    {
19    }

20}

21   使用 partial 关键字表明可在命名空间内定义该类、结构或接口的其他部分。所有部分都必须使用 partial 关键字。在编译时,各个部分都必须可用来形成最终的类型。各个部分必须具有相同的可访问性,如 publicprivate 等。
22
23如果将任意部分声明为抽象的,则整个类型都被视为抽象的。如果将任意部分声明为密封的,则整个类型都被视为密封的。如果将任意部分声明为基类型,则整个类型都将继承该类。
24
25    指定基类的所有部分必须一致,但忽略基类的部分仍继承该基类型。各个部分可以指定不同的基接口,最终类型将实现所有分部声明所列出的全部接口。在某一分部定义中声明的任何类、结构或接口成员可供所有其他部分使用。最终类型是所有部分在编译时的组合
26**分部修饰符不可用于委托或枚举声明中。
27   嵌套类型可以是分部的,即使它们所嵌套于的类型本身并不是分部的也如此。例如:
28class Container
29{
30    partial class Nested
31    {
32        void Test() { }
33    }

34    partial class Nested
35    {
36        void Test2() { }
37    }

38}

39
40处理分部类定义时需遵循下面的几个规则:
41
42   要作为同一类型的各个部分的所有分部类型定义都必须使用 partial 进行修饰。例如,下面的类声明将生成错误:
43public partial class A { }
44//public class A { }  // Error, must also be marked partial
45  partial 修饰符只能出现在紧靠关键字 classstruct 或 interface 前面的位置。
46
47  分部类型定义中允许使用嵌套的分部类型,例如:
48partial class ClassWithNestedClass
49{
50    partial class NestedClass { }
51}

52
53partial class ClassWithNestedClass
54{
55    partial class NestedClass { }
56}

57要成为同一类型的各个部分的所有分部类型定义都必须在同一程序集和同一模块(.exe 或 .dll 文件)中进行定义。分部定义不能跨越多个模块。
58
59类名和泛型类型参数在所有的分部类型定义中都必须匹配。泛型类型可以是分部的。每个分部声明都必须以相同的顺序使用相同的参数名。
60  下面的示例在一个分部类定义中声明类 CoOrds 的字段和构造函数,在另一个分部类定义中声明成员 PrintCoOrds。
61
62public partial class CoOrds
63{
64    private int x;
65    private int y;
66
67    public CoOrds(int x, int y)
68    {
69        this.x = x;
70        this.y = y;
71    }

72}

73
74public partial class CoOrds
75{
76    public void PrintCoOrds()
77    {
78        System.Console.WriteLine("CoOrds: {0},{1}", x, y);
79    }

80
81}

82
83class TestCoOrds
84{
85    static void Main()
86    {
87        CoOrds myCoOrds = new CoOrds(1015);
88        myCoOrds.PrintCoOrds();
89    }

90}

91
92
93According to MSDN.
94
95
96
原文地址:https://www.cnblogs.com/RuiLei/p/569616.html