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(也就是说:密封方法是被重写的方法,不是重写的方法不能被密封)

下面内容参考自://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();
  }
 }
}

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

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对我们的支持。如果你想了解更多相关内容请查看下面相关链接

(0)

相关推荐

  • C# WebApi 接口返回值不困惑:返回值类型详解

    前言:已经有一个月没写点什么了,感觉心里空落落的.今天再来篇干货,想要学习Webapi的园友们速速动起来,跟着博主一起来学习吧.之前分享过一篇C#进阶系列--WebApi接口传参不再困惑:传参详解,这篇博文内容本身很基础,没想到引起很多园友关注,感谢大家的支持.作为程序猿,我们都知道参数和返回值是编程领域不可分割的两大块,此前分享了下WebApi的传参机制,今天再来看看WebApi里面另一个重要而又基础的知识点:返回值.还是那句话:本篇针对初初使用WebApi的同学们,比较基础,有兴趣的且看看.

  • .NET/C#如何判断某个类是否是泛型类型或泛型接口的子类型详解

    前言 泛型:通过参数化类型来实现在同一份代码上操作多种数据类型.利用"参数化类型"将类型抽象化,从而实现灵活的复用.在.NET类库中处处都可以看到泛型的身影,尤其是数组和集合中,泛型的存在也大大提高了程序员的开发效率.更重要的是,C#的泛型比C++的模板使用更加安全,并且通过避免装箱和拆箱操作来达到性能提升的目的.因此,我们很有必要掌握并善用这个强大的语言特性. C#泛型特点: 1.如果实例化泛型类型的参数相同,那么JIT编辑器会重复使用该类型,因此C#的动态泛型能力避免了C++静态模

  • C#接口在派生类和外部类中的调用方法示例

    本文实例讲述了C#接口在派生类和外部类中的调用方法.分享给大家供大家参考,具体如下: C#的接口通过interface关键字进行创建,在接口中可以包含属性,方法等成员变量.接口的派生类可以对接口中的方法进行实现.一个类可以继承多个接口对这些接口中的方法进行实现,一个接口也可以派生多个类接口中的方法可以由这些类中的一个或多个进行实现.在接口的派生类中可以直接调用接口中的方法. 在派生类中调用举例: //接口 public interface IPersonalService { //接口中的方法

  • C#中实现判断某个类是否实现了某个接口

    有时我们需要判断某个类是否实现了某个接口(Interface),比如在使用反射机制(Reflection)来查找特定类型的时候. 简单来说,可以使用Type.IsAssignableFrom方法: typeof(IFoo).IsAssignableFrom(bar.GetType()); typeof(IFoo).IsAssignableFrom(typeof(BarClass)); 从字面意思可以看出,IsAssignableFrom表示BarClass类型能否赋值给IFoo接口,所以它返回t

  • C#抽象类和接口的区别分析

    很多C#的初学者在编程时都容易把抽象类和接口搞混,本文就为大家从概念上讲解抽象类和接口的区别: 一.抽象类: 含有abstract修饰符的class即为抽象类,抽象类是特殊的类,只是不能被实例化,可以创建一个变量,其类型是一个抽象类,并让它指向具体子类的一个实例:除此以外,具有类的其他特性:重要的是抽象类可以包括抽象方法,这是普通类所不能的.抽象方法只能声明于抽象类中,且不包含任何实现,派生类必须覆盖它们.另外,抽象类可以派生自一个抽象类,可以覆盖基类的抽象方法也可以不覆盖. 二.接口: 接口是

  • 深入解析C#中的泛型类与泛型接口

    泛型类 泛型类封装不是特定于具体数据类型的操作.泛型类最常用于集合,如链接列表.哈希表.堆栈.队列.树等.像从集合中添加和移除项这样的操作都以大体上相同的方式执行,与所存储数据的类型无关. 对于大多数需要集合类的方案,推荐的方法是使用 .NET Framework 类库中所提供的类. 一般情况下,创建泛型类的过程为:从一个现有的具体类开始,逐一将每个类型更改为类型参数,直至达到通用化和可用性的最佳平衡.创建您自己的泛型类时,需要特别注意以下事项: 将哪些类型通用化为类型参数. 通常,能够参数化的

  • C#中抽象类与接口的区别详解

    1.面向接口编程和面向对象编程是什么关系 首先,面向接口编程和面向对象编程并不是平级的,它并不是比面向对象编程更先进的一种独立的编程思想,而是附属于面向对象思想体系,属于其一部分.或者说,它是面向对象编程体系中的思想精髓之一. 2.接口的本质 接口,在表面上是由几个没有主体代码的方法定义组成的集合体,有唯一的名称,可以被类或其他接口所实现(或者也可以说继承).它在形式上可能是如下的样子: interface InterfaceName { void Method1(); void Method2

  • C#中类与接口的区别个人总结

    一.类与接口的区别 类:描述了一个实体,包括实体的状态,也包括实体可能发出的动作. 接口:定义了一个实体可能发出的动作.但是只是定义了这些动作的原型,没有实现,也没有任何状态信息. 1.接口与类区别: (1)接口有点象一个规范.一个协议,是一个抽象的概念: (2)而类则是实现了这个协议,满足了这个规范的具体实体,是一个具体的概念. (3)从程序角度,简单理解,接口就是函数声明,类就是函数实现.需要注意的是同一个声明可能有很多种实现. 2.接口与抽象类的区别: (1)A class can imp

  • 结合.net框架在C#派生类中触发基类事件及实现接口事件

    在派生类中引发基类事件 以下简单示例演示了在基类中声明可从派生类引发的事件的标准方法.此模式广泛应用于 .NET Framework 类库中的 Windows 窗体类. 在创建可用作其他类的基类的类时,应考虑如下事实:事件是特殊类型的委托,只可以从声明它们的类中调用.派生类无法直接调用基类中声明的事件.尽管有时需要事件仅由基类引发,但在大多数情形下,应该允许派生类调用基类事件.为此,您可以在包含该事件的基类中创建一个受保护的调用方法.通过调用或重写此调用方法,派生类便可以间接调用该事件. 注意:

  • 解析在C#中接口和类的异同

    不同点: 不能直接实例化接口. 接口不包含方法的实现. 接口可以多继承,类只能单继承. 类定义可以在不同的源文件之间进行拆分. 相同点: 接口.类和结构都可以从多个接口继承. 接口类似于抽象基类:继承接口的任何非抽象类型都必须实现接口的所有成员. 接口和类都可以包含事件.索引器.属性. 接口只能定义方法. 1. 类 类的分类有:抽象类(abstract).密封类(sealed).静态类(static) 1.1 抽象类 关键字: abstract 使用目的:若所有子类拥有共同的特性,可以把这个特性

随机推荐