[轉載]C#中的new修飾符以及多態

來源:互聯網
上載者:User

new關鍵字可以作為運算子,建立一個對象,也可以做修飾符;

作修飾符的時候,官方文檔的解釋為:

Used to hide an inherited member from a base class member.

中文意思為隱藏從基類中繼承了的成員。

那麼如何理解“隱藏是”的意思?

本人以為,這裡的隱藏是指隱藏了從基類中繼承了的成員,可以理解為,雖然子類從基類中繼承了該成員,但是該成員對子類不可見,或者說子類不認為該成員是從父類繼承得來的,而認為是自己建立的一個成員,和父類的一點關係也沒有。

假設有如下代碼: 

View Code -Interkey

 1 class Program 2  2     { 3  3         static void Main(string[] args) 4  4         { 5  5             Son s = new Son(); 6  6             s.methodB(); 7  7             Console.ReadLine(); 8  8         } 9  9     }10 10 11 11     public class Father12 12     {13 13         public virtual void methodA()14 14         {15 15             Console.WriteLine("Father.methodA");16 16         }17 17 18 18         public virtual void methodB()19 19         {20 20             methodA();21 21         }22 22     }23 23 24 24     public class Son : Father25 25     {26 26         public new void methodA()27 27         {28 28             Console.WriteLine("Son.methodA");29 29         }30 30     } 

當運行 s.methodB();的時候,會去運行s中從Father繼承了的methodA,但是程式發現Son類中並沒有從Father中繼承methodA方法(雖然Son類中有一個methodA方法,但是程式不認為該方法是從Father中繼承的)。因此,在這種情況下,程式會根據繼承鏈,尋找離Son類最近的基類,找到Father,然後再調用Father類中的methodA,因此程式輸出的是Father.methodA。

如果將new改成override,則得到的就是Son.methodA。

因此可以得出一些總結,override和new都是根據對象的運行時類型調用該類型的方法。當方法是override修飾的,則調用該方法。但是當方法是new修飾的,則認為該方法並沒有被繼承,轉而根據繼承鏈去找離該對象最近的基類的方法。

繼承虛函數時,無論使用new修飾還是override,都是一種多態的體現。多態的概念簡單的說就是A物體表現出B物體的行為,性質。在電腦科學中,多態是程式設計語言的一種特性,它允許不同類型的資料可以通過一個統一的介面進行操作。多態通常分為編譯時間多態和運行時多態。運行時的多態性就是指直到系統運行時,才根據實際情況決定實現何種操作。

無論使用new還是override,都是在啟動並執行時候才確定要調用哪個方法。再看下面的例子,可以更好的理解new和override和多態的關係:

View Code -Interkey

 1 class Program 2     { 3         static void Main(string[] args) 4         { 5             string input = Console.ReadLine(); 6             Person p = null; 7             if (input == "0") 8             { 9                 p = new GrandFather();10             }11             else if (input == "1")12             {13                 p = new Father();14             }15             else if (input == "2")16             {17                 p = new Son();18             }19             else20             {21                 p = new Person();22             }23             p.methodA();24             Console.ReadLine();25         }26     }27 28     public class Person29     {30         virtual public void methodA()31         {32             Console.WriteLine("Person.methodA");33         }34     }35 36     public class GrandFather : Person37     {38         override public void methodA()39         {40             Console.WriteLine("GrandFather.methodA");41         }42     }43     public class Father : GrandFather44     {45         public override void methodA()46         {47             Console.WriteLine("Father.methodA");48         }49     }50 51     public class Son : Father52     {53         public new void methodA()54         {55             Console.WriteLine("Son.methodA");56         }57     } 

p聲明為Person類的對象,但是根據輸入參數的不同,p在運行時表現為各自不同的類型。

當輸入0的時候,p表現為GrandFather類,調用GrandFather類中繼承的methodA方法,輸出GrandFather.methodA

當輸入1的時候,p表現為Father類,調用Father類中繼承的methodA方法,輸出Father.methodA

當輸入2的時候,p表現為Son類,調用Son類中繼承的methodA方法,但是由於Son類中methodA方法是new修飾的,因此認為Son類中繼承的methodA方法被隱藏了,不可見了,因此根據繼承鏈,調用Father類中的methodA,因此也是輸出 Father.methodA

當輸入其他字元時,p表現為Person類,調用Person類中繼承的methodA方法,輸出Person.methodA。

 

本文出自 “一隻部落格” 部落格,並進行了適量修改。

 

本文出自 “一隻部落格” 部落格,請務必保留此出處http://cnn237111.blog.51cto.com/2359144/1120179

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.