C# 中的接口和密封类

2020-09-27 18:44发布

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结尾。


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.jb51.net/article/75546.htm

注意:密封类中不能包含虚方法(virtual)和抽象方法(abstract),因为密封的类没有为派生类提供实现虚方法和抽象方法的机会。

在把类或者方法标记为sealed时要小心,以为这么做会严重限制他的使用。即使不希望他能继承一个类或重写类的某个成员,仍有可能在将来的某个时刻,有人会遇到预料不到的情形,

.NET基类库大量使用了密封类,使希望从这些类中派生出自己的第三方开发人员无法访问这些类,例如string就是一个密封类。


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(); 

    } 

  } 

}


密封类除了不能被继承外,其他与非密封类一样,密封方法则必须通过重写基类中的虚方法实现。




作者:Czhenya

链接:https://blog.csdn.net/Czhenya/article/details/76165396

来源:CSDN
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。