zl程序教程

您现在的位置是:首页 >  后端

当前栏目

C#引用访问权限分析

c#权限 分析 访问 引用
2023-06-13 09:15:31 时间

本文实例分析了C#引用访问权限问题。分享给大家供大家参考。具体分析如下:

同样代码表现的不同行为:
 
创建基类(Super)和派生类(Sub)每个类有一个字段field和一个公共方法getField,并且使用内联的方式初始化为1,方法getField返回字段field。C#和Java代码及运行结果如下

复制代码代码如下:
classSuper
{
       publicintfield=0;
 
       publicintgetField()
       {
           returnfield;
       }
}

classSub:Super
{
       publicintfield=1;
 
       publicintgetField()
       {
           returnfield;
       }
}

classProgram
{
       privatestaticvoidMain(string[]args)
       {
           Supersup=newSub();
           Console.WriteLine("sup.getField()result:"+sup.getField());
           Console.ReadKey();
       }
}


 
Java代码如下:
复制代码代码如下:
classSuper{
   publicintfield=0;
   publicintgetField(){
       returnfield;
   }
}
 
classSubextendsSuper{
   publicintfield=1;
   publicintgetField(){
       returnfield;
   }
}
 
publicclasspolymorphicDefects{
   publicstaticvoidmain(String[]args){
       Supersup=newSub();
       System.out.println("sup.getField()result:"+sup.getField());
   }
}

 
Java代码运行结果表现出了多态性,而C#的方法并没有表现出多态性。更具体的说C#中对象sub并没有调用自己实际类型Sub中的方法而是去调用父类的方法。
 
可能用惯了Java的童鞋,突然使用C#在一点上有些许不习惯,其实C#团队在这里加入了一个概念,就是引用访问权限,一个引用代表着他的访问权限,Sub的引用仅能对Sub类型中自己的方法进行访问。
 
当然C#的方法不是支持多态,只是使用虚方法来表现方法的多态性,可看下面的例子:
复制代码代码如下:classSuper
{
       publicintfield=0;
 
       publicvirtualintgetField()
       {
           returnfield;
       }
}

classSub:Super
{
       publicintfield=1;
 
       publicoverrideintgetField()
       {
           returnfield;
       }
}

classProgram
{
       privatestaticvoidMain(string[]args)
       {
           Supersup=newSub();
           Console.WriteLine("sup.getField()result:"+sup.getField());
           Console.ReadKey();
       }
}


 
接下来我想说说我对C#引入引用访问权限的看法。引入了引用访问权限的C#比Java更加的强大了,也比Java多了一个新的特性,当然事情都是有两个方面的,对引用那个访问权限的引入也使C#更加复杂与不易。

希望本文所述对大家的C#程序设计有所帮助。