国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

關于interface繼承來源的討論

開發 后端
關于interface繼承來源的討論主要是interface繼承是否與System.Object有關系的內容,那么本文就向你介紹相關的一些觀點,希望對你了解和學習有所幫助。

在.NET世界里,我們常常聽到的一句話莫過于“System.Object是一切類型的根,是所有類型的父類”,以至于我在《你必須知道的.NET》8.1節 以“萬物歸宗:System.Object”這樣的title為System.Object授予至高榮譽。所以,基于這樣的觀點就有了下面這句“接口是否也繼承于System.Object?”,事實上這正是今天在技術群里小小討論的一個插曲。

持“interface也繼承于object”,是基于以下的兩個觀點推斷的:

觀點一:

接口本質上也是一個class,因為接口類型編譯之后在IL中被標識為.class,既然是類那么不可避免的最終繼承于System.Object。

觀點二:

假如有如下的接口和實現接口的類型:

  1. // Release : code01, 2009/03/04                      
  2. // Author  : Anytao  
  3. // List    : IObjectable.cs  
  4. public interface IObjectable  
  5. {  
  6. }// Release : code02, 2009/03/04                      
  7. // Author  : Anytao  
  8. // List    : MyObject.cs  
  9. public class MyObject : IObjectable  
  10. {  

那么,對于IObjectable對象而言,下面的調用是可行的:

  1. // Release : code03, 2009/03/04                      
  2. // Author  : Anytao  
  3. // List    : Program.cs  
  4. class Program  
  5. {  
  6.     static void Main(string[] args)  
  7.     {  
  8.         IObjectable obj = new MyObject();  
  9.  
  10.         //Call Object instance methods  
  11.         obj.ToString();  
  12.         //Call Object static methods  
  13.         IObjectable.Equals(nullnull);  
  14.     }  
  15. }  

顯然,IObjectable類型變量obj可以訪問存在于System.Object中的實例方法ToString()和虛方法Equals,當然其他的幾個公共服務也不例外:GetType()、Equals()、GetHashcode()、ReferenceEquals(),也可以由此推斷interface可訪問Object方法的蛛絲馬跡。

不可否認,以上觀點的部分推理是完全正確的,但是卻遺憾的導致了錯誤的答案,所以在本文中我將明確的找出:interface不繼承于object的原因和原理。關于接口本質話題的深度討論,請參考《你必須知道的.NET》1.5 “玩轉接口”和7.4 “面向抽象編程:接口和抽象類”的詳細分析。

2 從面向對象尋找答案

為了找出接口繼承的原因,我想從接口存在的意義入手是最能夠說明問題的辦法?接口,就像面向對象設計中的精靈,為OO思想注入了靈魂和活力,接口突破了繼承在縱向上的擴展方向,在橫向給予對象以更靈活的支持機制。

接口,封裝了對于行為的抽象,定義了實現者必須遵守的契約。例如,實現了System.ICloneable接口的類型被賦予了“可以被拷貝”這樣的契約,實現了System.Collections.IEnumerable接口的類型被賦予了“可以被枚舉”這樣的契約,不同的接口定義了不同的契約,就像不同的法律約束了不同的行為。那么接口應該賦予的契約至少在層次上保持相對的單純和統一,如果為所有接口都無一例外的賦予GetType()、Equals()、GetHashcode()、ReferenceEquals()還有ToString()這樣的契約,未免使得接口的純潔和統一變得無從談起,例如強迫任何實現了System.ICloneable接口的類型同時遵守其他的約定是對ICloneable本身的侮辱。

從接口單一原則延伸思考,一個包含雜七雜八的接口定義顯然不是interface應該具有的純正血統,對于深諳面向對象為何物的.NET設計者而言,這是不言而喻的問題。所以,我們從接口本身的職責和意義出發,決定interface不從System.Object繼承是完全正確的。

3 在IL探求究竟

再次應用強大的IL武器來探求事實的真相,我們以Reflector打開所有的.NET既有接口,例如IList、IEmumerable、ICollection,都會有個共同的發現那就是你找不到extends System.Object這樣的標識:

  1. .class public interface abstract auto ansi ICloneable  
  2. {  
  3.     .custom instance void   
  4. System.Runtime.InteropServices.  
  5. ComVisibleAttribute::.ctor(bool) = { bool(true) }  
  6.     .method public hidebysig newslot abstract 
  7.  virtual instance object Clone() cil managed  
  8.     {  
  9.     }  

自定義類型也是如此,我們看看IObjectable的IL反編譯定義:

  1. .class public interface abstract auto ansi IObjectable  
  2. {  

而以extends標識繼承關系是IL代碼告訴我們真相的最佳證明。System.Object真是“萬物歸宗”嗎?

讓我們再次回眸一笑,把Object進行一番把玩,難道一切類型都得繼承自Object嗎?其實不然。以ILASM.exe進行IL代碼編譯時,有一個參數選項NOAUTOINHERIT,正如其解釋所描述的那樣:

  1. /NOAUTOINHERIT  Disable inheriting from System.Object by default 

顯然NoAutoInherit選項提供了為.NET類型“去掉帽子”的作用,簡單言之就是,在未指定基類時,禁止類型自動從Object繼承。

我們可以玩兒一個翻來覆去的IL游戲,將我們本文開始的Anytao.Insidenet.InterfaceInside.exe控制臺程序以ILDASM.exe工具Dump為IL代碼My.il,例如MyObject被反編譯為:

  1. .class public auto ansi beforefieldinit   
  2. Anytao.Insidenet.InterfaceInside.MyObject  
  3.        extends [mscorlib]System.Object  
  4.        implements Anytao.Insidenet.InterfaceInside.IObjectable  
  5. {  
  6.   .method public hidebysig specialname rtspecialname   
  7.           instance void  .ctor() cil managed  
  8.   {  
  9.     // Code size       7 (0x7)  
  10.     .maxstack  8  
  11.     IL_0000:  ldarg.0  
  12.     IL_0001:  call         
  13. instance void [mscorlib]System.Object::.ctor()  
  14.     IL_0006:  ret  
  15.   } // end of method MyObject::.ctor  
  16.  
  17. // end of class Anytao.Insidenet.InterfaceInside.MyObject  

我們可以選擇刪除其中所有extends繼承的代碼,再以ILASM.exe對其進行noautoinherit編譯,并生成

  1. ilasm /exe /output:noobject.exe /noautoinherit my.il 

新生成的noobject.exe程序將沒有從object繼承,某種程度上打破了“萬物歸宗”的創奇,MyObject就像一個無根之木,飄搖在我機器的某個深處。

4 結論

interface不從object繼承,那么足下高見呢?文章雖短,取一瓢飲之,暢也。

那么,我們該如何回答本文開始對此質疑的兩種觀點呢?

回答觀點一:

接口本質上還是一個類,但是一個特殊的類,它的特殊性表現在諸多的方面,例如所有的方法和屬性都是抽象的、支持多繼承等等,既然特殊那就特殊到底,不繼承于任何的父類也是其中之一吧。

雖然這種解釋未免牽強,但是如前文所述回到接口本源的角度而言,卻是最好的解釋。

回答觀點二:

.NET一切類型都隱式繼承于System.Object,那么對于實現了任何接口的類型而言,例如:

  1. // Release : code02, 2009/03/04                      
  2. // Author  : Anytao  
  3. // List    : MyObject.cs  
  4. public class MyObject : IObjectable  
  5. {  
  6. }  

其在本質上相當于:

  1. // Release : code02, 2009/03/04                      
  2. // Author  : Anytao  
  3. // List    : MyObject.cs  
  4. public class MyObject : Object, IObjectable  
  5. {  

所以對于MyObject實例obj而言,obj.ToString()實質是MyObject類繼承于object,而不代表接口IObjectable也繼承于object。那么IObjectable.Equals()則是編譯器做了手腳,將IObjectable.Equals()翻譯為Object.Equals()所致(來自腦袋高論,表示熱烈感謝)。事實上,對于接口聲明類型的方法調用,在實現機制上完全不同于一般的直接方法調用和虛方法分派機制。

【編輯推薦】

  1. C#顯式實現接口原理淺析
  2. C# interface學習經驗淺談
  3. C# interface使用實例分析
  4. 淺析abstract class和interface的不同
  5. 詳解abstract class和interface的本質
責任編輯:仲衡 來源: 博客園
相關推薦

2013-05-20 15:45:12

CSS

2011-05-19 15:51:54

測試專家

2010-07-13 15:36:33

2010-09-28 15:42:36

DHCP服務故障排除

2011-11-02 09:04:15

Node.js

2013-02-28 15:11:56

GitGitHub

2010-09-28 15:52:08

Cisco路由器DHC

2009-10-16 16:11:04

6類布線系統

2015-05-19 11:11:58

OpenFlowSDN

2017-07-12 16:32:55

2010-09-01 09:10:30

DHCP作用域

2023-12-28 16:36:35

大數據

2015-06-24 14:29:07

PaaSPaaS困境

2022-09-26 08:26:38

軟件定時器函數

2011-07-04 16:40:39

QT 串口 QML

2011-08-12 10:55:29

客戶服務物流平臺規劃

2009-06-18 09:51:25

Java繼承

2011-06-16 11:01:56

PHP繼承

2014-05-29 10:54:20

C++構造函數

2025-06-09 08:01:12

點贊
收藏

51CTO技術棧公眾號

妞干网在线视频观看| 亚洲国产一区二区视频| 国内外成人免费激情视频| 日韩欧美在线中字| 国产98在线|日韩| 欧美日韩综合视频| 91午夜精品| 伊人发布在线| 国产亚洲福利社区| www.亚洲色图.com| 欧美日本精品| 成人好色电影| 一本—道久久a久久精品蜜桃| 国产一区二区看久久| av大片在线观看| av成人综合网| 精品女同一区二区三区在线播放 | 成人高h视频在线| 国产在线精品一区二区三区不卡| 日本一区二区黄色| 日韩精品一区二区三区中文不卡 | 韩国女主播一区二区三区| 亚洲欧美日韩直播| 高潮久久久久久久久久久久久久| 成人久久网站| 国产精品成人观看视频免费| 99久久精品国产观看| 视频在线不卡| 欧美精品videosex性欧美| 国产一二区在线观看| 中文字幕在线观看| 国产日韩欧美二区| 亚洲欧洲av| www成人免费| 国产一区免费在线| 午夜一区二区三区在线观看| 成人在线一区| 国产成人一区二区三区别| 亚洲少妇30p| 国产综合色区在线观看| 国产精品嫩草影院久久久| 中文av在线全新| 精品视频在线观看网站| 成人ar影院免费观看视频| 国产激情在线视频| 91香蕉亚洲精品| 亚洲免费观看高清完整版在线 | 国产一区在线精品| 好操啊在线观看免费视频| 古典武侠综合av第一页| 亚洲福利一二三区| 欧美精品一区二区久久| 国产特级嫩嫩嫩bbb| 午夜精品一区二区三区在线视频| 99久久久久久| 欧美日韩午夜电影网| av动漫免费看| 欧美激情免费在线| 国产精品乱人伦中文| 日本一道高清一区二区三区| 先锋在线亚洲| 国产精品av在线播放| 亚洲成av人影院| 婷婷综合亚洲| 香蕉视频免费在线播放| 免费国产一区二区| 精品久久久久久久久久久久包黑料 | 亚洲成人av免费| 色偷偷综合网| 水莓100在线视频| 成人18视频| 欧美日韩成人高清| 丝袜亚洲精品中文字幕一区| 第九色区av在线| 欧美精品亚洲| 亚洲缚视频在线观看| 精品一区免费av| 日韩在线观看不卡| 妞干网在线免费视频| 97视频com| 亚洲二区视频在线| 中文字幕免费一区二区三区| 午夜在线免费观看视频| 欧美午夜精品一区二区三区| 欧美一级精品| 蜜桃tv在线播放| 成人免费在线看片| 日韩欧美精品在线| 国产一区二区三区黄视频 | 欧美日韩一二区| 久久人人超碰| 欧美激情喷水| 国产成人免费观看| 国产一区视频在线| 国产丝袜精品视频| 天天色综合天天| 国产一区二区在线电影| 久久久亚洲综合网站| av日韩中文字幕| 中文字幕av一区| 精品一区91| 另类小说第一页| 国产精品视频地址| 欧美丰满嫩嫩电影| 国产成人午夜精品5599| 老司机精品在线| 成人精品福利| 日韩欧美在线一区二区三区| 在线亚洲高清视频| 91一区二区三区在线播放| 国产亚洲欧美日韩在线观看一区二区| 黄色网页在线免费观看| 日本国产在线播放| 555www成人网| 亚洲开心激情网| www欧美成人18+| 国内精品久久久| 精品magnet| 免费成人av在线| 成人h动漫精品一区二区器材| 亚洲私人影吧| 99久久免费观看| 国产精品一区二区三区成人| 欧美va在线播放| 亚洲色图视频网站| 日本美女一区二区三区| 老牛国内精品亚洲成av人片| 国产在线观看a| 超清福利视频| 美脚丝袜一区二区三区在线观看| 久久天天东北熟女毛茸茸| 久久99影院| 国产精品久久久亚洲| 制服丝袜亚洲色图| 不卡的av电影| 国产黄人亚洲片| 午夜亚洲福利在线老司机| 亚洲欧美日本伦理| 99爱在线观看| 久久精品视频免费看| 久无码久无码av无码| 在线观看免费黄色| 97高清视频| 亚洲精品天堂| 四虎5151久久欧美毛片| 99精品全国免费观看视频软件| 97视频精品| 国产探花在线精品一区二区| 亚洲欧洲日本mm| 蜜桃视频一区| 亚洲第一中文av| 欧美激情专区| 国产成人精品久久久| 亚洲精品有码在线| 色猫猫国产区一区二在线视频| 成人黄页在线观看| 亚洲黄色精品| 精品久久精品| 白嫩亚洲一区二区三区| 91亚洲天堂| 香蕉国产在线| 男男视频在线观看网站| 亚洲一二三四区不卡| 国产一区二区三区毛片| 亚洲xxx自由成熟| 91成人在线视频观看| 日本h片在线看| 性一交一乱一区二区洋洋av| 亚洲欧美一区二区三区国产精品| 欧美一区二区三级| 午夜影院在线观看视频| 欧美一级黄色片视频| 最新视频 - x88av| 欧美精品成人一区二区在线观看| 国产精品一区二区3区| 97avcom| 在线视频免费一区二区| 欧美精品一区二区三区很污很色的 | 都市激情久久| 国产香蕉久久| 天堂av中文在线观看| 污片在线免费观看| 浮生影视网在线观看免费| 欧美日韩影视| 日本视频在线观看一区二区三区| 香蕉自在线视频| 中文字幕国产在线| 在线观看一级片| 九色在线视频| 亚洲1卡2卡3卡4卡乱码精品| av在线资源站| 大片免费在线观看| 神马午夜伦理不卡| 色老头在线一区二区三区| 中国色在线日|韩| 精品人伦一区二区三区蜜桃网站 | 精品久久一二三区| 亚洲人成精品久久久久| 国产精品女人毛片| 国产精品久久久一区麻豆最新章节|