自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

C#對接口成員訪問分析

開發(fā) 后端
這里介紹C#對接口成員訪問,如果底層成員的命名與繼承而來的高層成員一致,那么底層成員將覆蓋同名的高層成員。

在向大家詳細介紹C#對接口成員訪問之前,首先讓大家了解下C#對接口方法的調(diào)用,然后全面介紹C#對接口成員訪問。

C#對接口成員訪問

C#對接口方法的調(diào)用和采用索引指示器訪問的規(guī)則與類中的情況也是相同的。如果底層成員的命名與繼承而來的高層成員一致,那么底層成員將覆蓋同名的高層成員。但由于接口支持多繼承,在多繼承中,如果兩個父接口含有同名的成員,這就產(chǎn)生了二義性(這也正是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) ; // 正確調(diào)用IRing.Count  
  15. }  

上面的例子中,前兩條語句rs .Count(1)和rs .Count = 1會產(chǎn)生二義性,從而導致編譯時錯誤,因此必須顯式地給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. }  

調(diào)用Num.Add(1) 會導致二義性,因為候選的重載方法的參數(shù)類型均適用。但是,調(diào)用Num.Add(1.0) 是允許的,因為1.0 是浮點數(shù)參數(shù)類型與方法IInteger.Add()的參數(shù)類型不一致,這時只有IDouble.Add 才是適用的。不過只要加入了顯式的指派,就決不會產(chǎn)生二義性。

接口的多重繼承的問題也會帶來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) ; // 調(diào)用ILeft. FWay  
  13. ((IBase)d). FWay (1) ; // 調(diào)用IBase. FWay  
  14. ((ILeft)d). FWay (1) ; // 調(diào)用ILeft. FWay  
  15. ((IRight)d). FWay (1) ; // 調(diào)用IBase. FWay  
  16. }  

上例中,方法IBase.FWay在派生的接口ILeft中被Ileft的成員方法FWay覆蓋了。所以對d. FWay (1)的調(diào)用實際上調(diào)用了。雖然從IBase-> IRight-> IDerived這條繼承路徑上來看,ILeft.FWay方法是沒有被覆蓋的。我們只要記住這一點:一旦成員被覆蓋以后,所有對其的訪問都被覆蓋以后的成員"攔截"了。

【編輯推薦】

  1. C# this關鍵字詳解
  2. C#調(diào)用析構(gòu)方法詳解
  3. C#釋放托管資源簡單描述
  4. C#單路代理簡單分析
  5. C#文法產(chǎn)生式概述
責任編輯:佚名 來源: 博客園
相關推薦

2009-08-03 18:26:18

C#定義接口成員

2009-08-24 10:06:31

C#接口成員

2009-08-31 17:02:28

C#接口編程

2010-07-26 09:20:48

C#

2009-08-18 10:30:30

C#枚舉

2009-08-06 16:01:30

C#接口成員

2009-08-24 11:02:52

C#接口映射

2009-08-24 09:55:26

C#接口轉(zhuǎn)換

2009-08-24 11:20:03

C#接口

2009-08-25 10:44:08

C#接口定義接口

2009-08-14 17:58:05

C#接口方法

2009-08-03 18:08:39

C# ICloneab

2009-08-31 13:18:09

C# IWebMess

2009-08-31 15:55:17

C#實現(xiàn)Strateg

2009-08-24 10:31:37

C#接口繼承

2009-08-25 10:57:09

C#接口

2009-08-25 17:55:52

C#實現(xiàn)Strateg

2009-08-10 10:04:25

C#抽象類C#接口

2009-08-19 11:21:02

C# ListBox控

2009-08-26 16:46:06

C# ThreadSt
點贊
收藏

51CTO技術棧公眾號