API
Application Programming Interface 應用程序接口
接口
定義 :指描述可屬于任何類或結構的一組相關功能。
接口的成員可以是方法(不能有方法體),屬性,事件和索引器,但不能包含常數,字段,運算符,實例構造函數析構函數或類,也不能包括任何種類的靜態成員,接口中的成員不允許添加訪問修飾符,(默認都是public)
簡介:
1. 接口是一個引用類型,通過接口可以實現多重繼承。
2. C#中接口的成員不能有new、public、protected、internal、private等修飾符。
3. 接口中只能聲明"抽象"成員(所以不能直接下一步對接口進行實例化(即不能使用new操作符聲明一個接口的實例對 象)),而不能聲明共有的域或者私有的成員變量。
4. 接口名稱一般都以“I”作為首字母(當然不這樣聲明也可以),這也是接口和類的一個區別之一。
5. 接口成員不能有static、abstract、override、virtual修飾符,使用new修飾符不會報錯,但會給出警告說不需要關鍵字new。
6. 接口一旦被實現,實現類必須實現接口中的所有成員,除非實現類本身是抽象類(通過具體的可執行代碼實現接口抽象成員的操作)。
接口名稱習慣上以I開頭,跟在I后面的第一個字符也是大寫,一般一able結尾。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
namespace _10._1接口的聲明 { interface IEatable { //接口默認聲明為public ,類的默認聲明private //屬性 接口中不能有訪問修飾符 //string _name //由于接口中不能有字段,所以熟悉經常被寫成自動屬性; string Name { get ; set ; } //方法 方法也不能有方法體 void Write(); string Read(); } } |
接口的實現和繼承
- 實現過程必須在實現接口的類中完成
- 類的繼承具有單根性,接口可以多重繼承
- 同一接口中成員名不能相同即使類型不同也不行
- 如果派生接口中對顯示基接口中的成員進行重新定義是,需要使用new來解除警告
開放封閉性原則
定義:
軟件實體應該可以擴展,但是不可以修改
特性:
對拓展開放的
對修改是封閉的。開放即可以操作,關閉即不可以操作
以上都是我們通常用的
隱式實現接口:
既可以用接口調用方法,也可以用具體類調用方法
顯式實現接口:
實現接口的方法前不能用訪問修飾符public,必須顯示指定接口名稱
返回值類型 接口名稱.接口方法
只能通過接口來調用,而不是通過具體類來做
同時隱世和顯式實現接口
這樣完成了對一個接口成員提供多分實現實體,訪問時可以用類的實例和接口的引用來分別調用這兩種實現實體。顯式才是真正的接口實現方式
結論:當顯式實現方式存在時,隱式實現方式就失效了。但這不能表示顯式實現方式就不好,當一個類實現多個接口中具有相同的方法是,用顯式方式專門實現某個接口的方法是就顯得非常有用。
接口中的注意事項:
- 接口中所有的方法都是抽象方法,所以接口不能被實例化
- 一個類可以實現多個接口,被實現的接口之間用逗號分隔開
- 一個接口可以繼承多個接口,接口之間也要用逗號分隔開,,,
密封類與密封方法
密封類
并不是所有的類都可以被繼承,不能繼承的類稱為密封類,甩關鍵字:sealed
適用場合:如果對庫,類或者自己編寫的其他類進行操作,則重寫某些功能會導致編譯錯誤。因商業原因吧類或方法標記為sealed ,以防第三方以違反注冊協議的方式擴展類。
密封方法
定義:用修飾符sealed進行標記的方法
作用:使用sealed修飾符可以防止派生進一步重寫該方法、
注意:如果實例方法包含sealed修飾符,則必須也包含override修飾符
要在方法中適應sealed關鍵字 ,必須現在基類上將其聲明為重寫,如果基 類上不希望有重寫的方法或者屬性,就不要將其聲明為virtual(也就是說:密封方法是被重寫的方法,不是重寫的方法不能被密封)
下面內容參考自:http://www.jfrwli.cn/article/202249.html
注意:密封類中不能包含虛方法(virtual)和抽象方法(abstract),因為密封的類沒有為派生類提供實現虛方法和抽象方法的機會。
在把類或者方法標記為sealed時要小心,以為這么做會嚴重限制他的使用。即使不希望他能繼承一個類或重寫類的某個成員,仍有可能在將來的某個時刻,有人會遇到預料不到的情形
.NET基類庫大量使用了密封類,使希望從這些類中派生出自己的第三方開發人員無法訪問這些類,例如string就是一個密封類。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace qq { class class1 { public virtual void seaText() { Console.WriteLine( "這是一個未密封的方法!" ); } } sealed class class2 : class1 { public sealed override void seaText() { Console.WriteLine( "這是一個密封的方法!" ); } } /*class class3 : class2//密封類不能被繼承 { public override void seaText()//不能重寫密封方法 { Console.WriteLine("這是一個不能運行的方法!"); } }*/ class Program { static void Main( string [] args) { class2 c2 = new class2(); c2.seaText(); Console.ReadLine(); } } } |
密封類除了不能被繼承外,其他與非密封類一樣,密封方法則必須通過重寫基類中的虛方法實現。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對服務器之家的支持。如果你想了解更多相關內容請查看下面相關鏈接
原文鏈接:https://blog.csdn.net/Czhenya/article/details/76165396