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(也就是说:密封方法是被重写的方法,不是重写的方法不能被密封)
下面内容参考自:https://www.zzvips.com/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