C#虚基类继承与接口的区别

类 定义新的数据类型以及这些新的数据类型进行相互操作的方法 定义方式:

   class Cat {
      // ..........
   }
   class Cat : object {
      //  ..........
   }

C#中所有的类都是默认由object类派生来的,显示指定或者省略效果是一样的,所以上面的两个例子是完全相同的。 C#中类包括:抽象类、密封类、非抽象类 abstract:表示修饰的类不完整,也就是抽象类,只能用做基类。 在使用是不能直接实例化,不能使用new运算符。 sealed:表示修饰的类不可派生,也就是密封类。 base:访问最近的基类,也就是当前类继承的类。


    class Cat:Animal
    {
      public void Cat()
      {
        base.Eat();
      }
    }

以上例子中base代表Animal。 注意:base只能在类的内部使用。 接口 一个接口定义一个协定。接口可以看成是特殊的抽象类,但是又有所区别。 一个接口可以从多个基接口继承,而一个类或结构可以实现多个接口。 接口可以包含方法、属性、事件和索引器。接口本身不提供它所定义的成员的实现,而抽象类中可以提供定义成员的实现。 接口只指定实现该接口的类或结构必须提供的成员。 接口本质上是一种类 不过他与类的区分还是很明显的——不能实例化 他的精髓在于提供一些类共同的地方,而且能“多继承” 我们知道所谓对象其实是数据和方法的封装。接口的作用更多的是工程上的,一般上我们用他来封装通用的行为,来达到程序的多态。 不必用object的观点来统一接口,在我的感觉中,继承简化对象结构,增加代码重用,接口抽象行为。 1. 接口本质上是类吗 这个,要看你认为“类的本质是什么”了,过多纠缠于这个说法,很容易陷入文字之争,意义不大。 2. 接口和类有什么区别和联系,主要是联系 区别: 类的定义需要“实现”,接口的定义只需要“声明”; 类能实例化出一个对象,接口不能; 类只能单根继承,接口可以多根继承; 继承一个类,相当于借用了它已实现的功能,实现一个接口,相当于对外做了一个承诺; …… 联系:类可以“实现”接口 3. 接口是否具备类的特征 这要看你认为哪些是“类的特征”,hehe,比如,“编译后会生成一个 .class 文件”算不算特征…… 4. 接口是否是Object 不是。但可以用一个接口型的变量来引用一个对象,而且,被引用的对象,说到底,一定是一个 Object。 1、纯虚类与接口不同的是,纯虚类可以包含一些实现 2、用纯虚类包含一些基本的功能或方法 3、用接口来定义客户端与组件之间的通讯方法 4、虚基类的实现的变化可能会影响派生类 5、使用接口要比使用继承具有更强的适用性 接口的一些特征; 不可以包含任何实现;没有构造方法;任何成员都隐式声明为public; 接口是负责功能的定义,项目中通过接口来规范类,操作类以及抽象类的概念! 而类是负责功能的具体实现! 在类中也有抽象类的定义,抽象类与接口的区别在于: 抽象类是一个不完全的类,类里面有抽象的方法,属性,也可以有具体的方法和属性,需要进一步的专业化。 但接口是一个行为的规范,里面的所有东西都是抽象的! 一个类只可以继承一个基类也就是父类,但可以实现多个接口 PS:接口除了规范一个行为之外,在具体项目中的实际作用也是十分重要的,在面向对象的设计原则以及设计模式的使用中,无不体现作为一个接口的使用好处,最直接的就是设计原则中OCP(开放封闭原则),我们使用接口,而不需要关心他的具体实现,具体实现的细节变化也无关客户端(使用接口的类)的使用,对与扩展是开放的,我们可以另写一个接口的实现来扩展当前程序,而不影响上层的使用,但对修改是封闭的,即我们不能够再去修改接口的定义,当然这个 “不能够”是指在规范原则上不应该这么做! 接口的使用–多态的实现:

    public interface IPolimorphism()
    {
       void Say();
    }

建立一个Class1.cs文件,定义两个类,扩展IPolimorfism:

using System;
using System.Windows.Forms;
namespace NorthWind
{
   public class Red:IPolimorphism  //实现接口的方法
   {
      public void Say()  //不需要指定override关键字
      {
          MessageBox.Show("Red!");
      }
   }
     
   public class Yello:IPolimorphism
   {
      public void Say() //不需要指定override关键字
      {
         MessageBox.Show("Yello!");
      }
   }
     
}

另一个MainFrm.cs文件,应用程序入口处:

using System;
using System.Windows.Forms;
namespace NorthWind {
   public class MainFrm : System.Windows.Forms {
      [STAThread]
      static void Main() {
         IPolimorphism red = new Red();
         red.Say();
         IPolimorphism yello = new Yello();
         yello.Say();
      }

   }
}

举个例子,有一个老汉,做了一个面饼,给了他的几个儿子,老大用这个饼,加上点馅,包一下,做成了包子,老二用这个面饼,在外面刷上油,撒上料,烤一烤,做成了土家烧饼,老三呢,胡乱做,在饼上抹上乱七八糟的东西,烤一烤,做成了披萨饼.基类和派生类的关系就是这样,基类提供了基本的实现,派生类就在上面添料,最终就成了每个人心中想要的饼.

那接口的故事则不一样,老汉没有给众人面,老汉这回给儿子们画了一个饼的设计图,规定了这个饼的厚度,直径等等,然后把这个规格表发给儿子们了,儿子们拿着画的饼,各自按自己的想法去做了.

两个故事的区别告诉我们,接口是一种规格,是一个统一的标准,在实际应用中,接口有两方法的作用.

1。通过接口更容易表现设计,更容易沟通,而且接口是没有实现代码的,因此,定好接口,再写实现代码,就算设计上有变动,也可以通过接口轻易实现修改.而如果不用接口的话,你将直接去写类,好不容易实现了一个类的代码,如果设计上有少许的变动,就要去改代码.

2。接口是写类的实现者看的,这好比建筑图纸是画给施工工人看的.

posted @ 2016-06-16 14:05  孤冢清风  阅读(1961)  评论(0编辑  收藏  举报