C# 中的接口和密封类

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


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


  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

陈言必行

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值