c#访问修饰符

类修饰符:public、internal、partial、abstract、sealed、static

成员修符:public、protected、private、internal、sealed、abstract、virtual、override、readonly、const


         Public:最开放,所有的本程序集以及其他的程序集里面的对象都能够访问


         Protected:比较开放,自身成员以及子类成员可访问


         Private:只有自身成员才能够访问


         Internal:本程序集内的成员可以访问


         Partial:部分类,可以将一个类分成几部分写在不同文件中,最终编译时将合并成一个文件,且各个部

分不能分散在不同程序集中


         Abstract:修饰类的时候表示该类为抽象类,不能够创建该类的实例。修饰方法的时候表示该方法需要

由子类来实现,如果子类没有实现该方法那么子类同样是抽象类;且含有抽象方法的类一定是抽象类


         Sealed:修饰类时表示该类不能够被继承,修饰方法时表示该方法不能被覆写。


         Static:修饰类时表示该类时静态类,不能够实例化该类的对象,既然不能实例化该类,那么这个类也

就不能够含有对象成员,即该类所有成员为静态;修饰类成员时,该成员为类成员,只能通过【类.成员名】的方

式访问

         当static修饰构造函数时,构造函数不能含有任何参数,不能含有修饰符,构造函数不能对对象成员进

行初始化操作。但是能够对静态成员进行初始化或者调用。不能保证他在什么时候执行,却能保证在第一次使用类

型前执行。在静态构造函数中初始化的静态成员为最终初始化结果。例如:

                      public static int test = 0;

                   static Person()

                   {

                       test = 3;

           }


        static void Main(string[] args)

        {

            Console.WriteLine(Person.test);//运行结果为3

}

也就是说相当于:

public static int test;

static Person()

{

      test=3;

}

         Virtual:修饰方法成员,表示虚方法。父类可以含有该类的实现,子类可以覆写该函数。


         Override:表示该方法为覆写了父类的方法。


         Readonly:修饰字段,表示该字段为只读字段。


注意:readonly修饰引用类型时由于操作不当可能修改该只读对象状态。例如:

Readonly List<Person> persons=….;

我们可能在某些地方对persons 进行了修改:persons.add(new Person());


         Const:修饰字段,表示该字段为只读字段。并且在编译时必须能够明确知道该字段的值,其值是硬编码

到程序中去的,修改了该类型成员后需要重新编译才能使修改生效。

         而readonly是运行时只读,内容在运行时确定,所以修改了readonly类型成员后无需重新编译即可生效

         Readonly不能修饰局部变量,const可以。

注意:当一个类或方法没有被任何修饰符修饰时,默认为internal: 
C#用多种修饰符来表达类的不同性质。根据其保护级C#的类有五种不同的限制修饰符:

public可以被任意存取; 
protected只可以被本类和其继承子类存取; 
internal只可以被本组合体(Assembly)内所有的类存取,组合体是C#语言中类被组合后的逻辑单位和物理单位,

其编译后的文件扩展名往往是“.DLL”或“.EXE”。

protected internal唯一的一种组合限制修饰符,它只可以被本组合体内所有的类和这些类的继承子类所存取。 
private只可以被本类所存取。 
如果不是嵌套的类,命名空间或编译单元内的类只有public和internal两种修饰。

new修饰符只能用于嵌套的类,表示对继承父类同名类型的隐藏。

abstract用来修饰抽象类,表示该类只能作为父类被用于继承,而不能进行对象实例化。抽象类可以包含抽象的成

员,但这并非必须。abstract不能和new同时用。下面是抽象类用法的伪码:

abstract class A 
{ 
public abstract void F(); 
} 
abstract class B: A 
{ 
public void G() {} 
} 
class C: B 
{ 
public override void F() 
{ 
//方法F的实现 
} 
}

抽象类A内含一个抽象方法F(),它不能被实例化。类B继承自类A,其内包含了一个实例方法G(),但并没有实现抽象

方法F(),所以仍然必须声明为抽象类。类C继承自类B,实现类抽象方法F(),于是可以进行对象实例化。

sealed用来修饰类为密封类,阻止该类被继承。

你可能感兴趣的:(修饰符)