C#对接口成员访问分析

在向大家详细介绍C#对接口成员访问之前,首先让大家了解下C#对接口方法的调用,然后全面介绍C#对接口成员访问。

在大祥等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供成都网站设计、网站建设、外贸网站建设 网站设计制作定制网站,公司网站建设,企业网站建设,成都品牌网站建设,成都全网营销推广,外贸网站制作,大祥网站建设费用合理。

C#对接口成员访问

C#对接口方法的调用和采用索引指示器访问的规则与类中的情况也是相同的。如果底层成员的命名与继承而来的高层成员一致,那么底层成员将覆盖同名的高层成员。但由于接口支持多继承,在多继承中,如果两个父接口含有同名的成员,这就产生了二义性(这也正是C#中取消了类的多继承机制的原因之一),这时需要进行显式的定义:

 
 
 
  1. using System ;  
  2. interface ISequence {  
  3. int Count { get; set; }  
  4. }  
  5. interface IRing {  
  6. void Count(int i) ;  
  7. }  
  8. interface IRingSequence: ISequence, IRing { }  
  9. class CTest {  
  10. void Test(IRingSequence rs) {  
  11. //rs.Count(1) ; 错误, Count 有二义性  
  12. //rs.Count = 1; 错误, Count 有二义性  
  13. ((ISequence)rs).Count = 1; // 正确  
  14. ((IRing)rs).Count(1) ; // 正确调用IRing.Count  
  15. }  

上面的例子中,前两条语句rs .Count(1)和rs .Count = 1会产生二义性,从而导致编译时错误,因此必须显式地给rs 指派父接口类型,这种指派在运行时不会带来额外的开销。

再看下面的例子:

 
 
 
  1. using System ;  
  2. interface IInteger {  
  3. void Add(int i) ;  
  4. }  
  5. interface IDouble {  
  6. void Add(double d) ;  
  7. }  
  8. interface INumber: IInteger, IDouble {}  
  9. class CMyTest {  
  10. void Test(INumber Num) {  
  11.  
  12. // Num.Add(1) ; 错误  
  13. Num.Add(1.0) ; // 正确  
  14. ((IInteger)n).Add(1) ; // 正确  
  15. ((IDouble)n).Add(1) ; // 正确  
  16. }  

调用Num.Add(1) 会导致二义性,因为候选的重载方法的参数类型均适用。但是,调用Num.Add(1.0) 是允许的,因为1.0 是浮点数参数类型与方法IInteger.Add()的参数类型不一致,这时只有IDouble.Add 才是适用的。不过只要加入了显式的指派,就决不会产生二义性。

接口的多重继承的问题也会带来C#对接口成员访问上的问题。例如:

 
 
 
  1. interface IBase {  
  2. void FWay(int i) ;  
  3. }  
  4. interface ILeft: IBase {  
  5. new void FWay (int i) ;  
  6. }  
  7. interface IRight: IBase  
  8. { void G( ) ; }  
  9. interface IDerived: ILeft, IRight { }  
  10. class CTest {  
  11. void Test(IDerived d) {  
  12. d. FWay (1) ; // 调用ILeft. FWay  
  13. ((IBase)d). FWay (1) ; // 调用IBase. FWay  
  14. ((ILeft)d). FWay (1) ; // 调用ILeft. FWay  
  15. ((IRight)d). FWay (1) ; // 调用IBase. FWay  
  16. }  

上例中,方法IBase.FWay在派生的接口ILeft中被Ileft的成员方法FWay覆盖了。所以对d. FWay (1)的调用实际上调用了。虽然从IBase-> IRight-> IDerived这条继承路径上来看,ILeft.FWay方法是没有被覆盖的。我们只要记住这一点:一旦成员被覆盖以后,所有对其的访问都被覆盖以后的成员"拦截"了。

本文名称:C#对接口成员访问分析
本文链接:http://www.hantingmc.com/qtweb/news39/229189.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联