zoukankan      html  css  js  c++  java
  • abstract virtual interface区别

    interface用来声明接口

    1.只提供方法的规则约束,不提供方法的主体。

    例:

    public interface IPerson

    {

    void getName();//不包含主体方法

    }

    2.方法不能用public abstract等修饰,无字段变量,无构造函数。

    3.方法可包含参数

    public interface IPerson

    {

    void getAge(string s);

    }

    例1

    public interface IPerson

    {

    IPerson();//错误

    string name;//错误

    public void getIDcard();//错误

    void getName();//正确

    void getAge(string s);//正确

    }

    实现interface的类

    1.与继承类的格式一致,如 public class Chinese:IPerson{}

    2.必须实现interface中的各个方法

    例2,继承例1

    public class Chinese:IPerson

    {

    public Chinese(){}//添加构造函数

    public void getName(){}//实现getName()

    public void getAge(){}//实现getAge()

    }

    abstract用来声明抽象类、抽象方法

    1.抽象方法所在类必须为抽象类。

    2.抽象类不能直接实例化,必须由其派生类实现。

    3.抽象方法不包含方法主体,必须由派生类以override方式实现此方法,这点跟interface中的方法类似


    public abstract class Book
    {
    public Book()
    {   
         }

    public abstract void getPrice();      //抽象方法,不含主体
            public virtual void getName()   //虚方法,可覆盖
            {
          Console.WriteLine("this is a test:virtual getName()");
                 }
            public virtual void getContent()   //虚方法,可覆盖
            {
          Console.WriteLine("this is a test:virtual getContent()");
                 }
    public void getDate()                           //一般方法,若在派生类中重写,须使用new关键字
            {
          Console.WriteLine("this is a test: void getDate()");
                 }
    }

    public class JavaBook:Book
    {
          public override void getPrice() //实现抽象方法,必须实现
          {
    Console.WriteLine("this is a test:JavaBook override abstract getPrice()");
    }
          public override void getName()   //覆盖原方法,不是必须的
          {
    Console.WriteLine("this is a test:JavaBook override virtual getName()");
    }
    }

    测试如下:
    public class test
       {
        public test()
        {
         JavaBook jbook=new JavaBook();
         jbook.getPrice();      //将调用JavaBook中getPrice()
         jbook.getName();      //将调用JavaBook中getName()
        jbook.getContent();    //将调用Book中getContent()
         jbook.getDate();       //将调用Book中getDate()
        
        }
        public static void Main()
        {
    test t=new test();
        }
       }

    virtual标记方法为虚方法
    1.可在派生类中以override覆盖此方法
    2.不覆盖也可由对象调用
    3.无此标记的方法(也无其他标记),重写时需用new隐藏原方法

    abstract与virtual: 方法重写时都使用 override 关键字
    interface中的方法和abstract方法都要求实现

    overrid和new

    //override不能重写非虚方法或静态方法。
    //所重写的基方法必须是虚拟的、抽象的或重写的。
    //所以说虚(virtual)成员与重写(override)成员是配对使用的,
    //虽然也可以用new来"隐藏"虚成员

    //下面通过例子来看看重写与隐藏的区别,从而进一步理解虚成员的作用。
    //重写部分----------

    public class MyBaseClass
    {
      public virtual void DoSomething()
         {
           Console.WriteLine("Base imp");
         }
    }

    public class MyDerivedClass:MyBaseClass
    {
      public override void DoSomething()
         (
           Console.WriteLine("Derived imp");
         }
    }

    //其中重写方法将替换基类中的执行代码,这样下面的代码就将使用替换代码,
    //即使这是通过基类进行的,情况也是这样:

         MyDerivedClass myObj=new MyDerivedClass();
         MyBaseClass myBaseObj;
         myBaseObj=myObj;
         myBaseObj.DoSomething();
      
    //结果如下:

         Derived imp
      

    //另外,还可以使用下面的代码隐藏基类方法:
    public class MyBaseClass
    {
    public virtual void DoSomething()
         {
           Console.WriteLine("Base imp");
         }
    }

    public class MyDerivedClass:MyBaseClass
    {
      new public void DoSomething()
         {
            Console.WriteLine("Derived imp");
         }
    }
    //基类方法不必是虚拟的,但结果是一样的,上面的代码只需要修改行。
    //对于基类的虚拟方法和非虚拟方法来说,其结果如下:
           Base imp
    //尽管隐藏了基类的执行代码,但仍可以通过基类访问它。

  • 相关阅读:
    Jackrabbit 中Session最佳实践
    Android 学习历程
    SmartFoxServer 学习笔记 002
    互联网的下一代
    VirtualBox 中 安装 Ubuntu Desktop 10 桌面分辨率的调整
    学习 SmartFoxServer 笔记 001
    手工转换中缀式与前、后缀式
    汉字传值奇数乱码问题解决策略
    git权限管理工具gitolite使用笔记(一)
    git 安装笔记
  • 原文地址:https://www.cnblogs.com/Mac_Hui/p/1739364.html
Copyright © 2011-2022 走看看