zoukankan      html  css  js  c++  java
  • 抽象方法与虚方法(转)

    虚方法和抽象方法都可以供派生类重写,它们之间有什么区别呢?

    1. 虚方法必须有实现部分,抽象方法没有提供实现部分,抽象方法是一种强制派生类覆盖的方法,否则派生类将不能被实例化。如:
    //抽象方法
    public abstract class Animal
    {
        
    public abstract void Sleep();
        
    public abstract void Eat();
    }

    //虚方法
    public class Animal
    {
        
    public virtual void Sleep(){}
        
    public virtual void Eat(){}
    }

    2. 抽象方法只能在抽象类中声明,虚方法不是。其实如果类包含抽象方法,那么该类也是抽象的,也必须声明为抽象的。如:
    public class Animal
    {
        
    public abstract void Sleep();
        
    public abstract void Eat();
    }

    编译器会报错:
    Main.cs(10): 'VSTest.Animal.Sleep()' is abstract but it is contained in nonabstract class 'VSTest.Animal'
    Main.cs(11): 'VSTest.Animal.Eat()' is abstract but it is contained in nonabstract class 'VSTest.Animal'

    3. 抽象方法必须在派生类中重写,这一点跟接口类似,虚方法不必。如:

    public abstract class Animal
    {
        
    public abstract void Sleep();
        
    public abstract void Eat();
    }

    public class Cat : Animal
    {
        
    public override void Sleep()
        {
            Console.WriteLine( 
    "Cat is sleeping" );
        }
        
    // we need implement Animal.Eat() here

    }


    编译器会报错:Main.cs(14): 'VSTest.Cat' does not implement inherited abstract member 'VSTest.Animal.Eat()',因为我们没有实现抽象类中所有抽象方法。

    ---------------------------------------------------------------------------------------------------------------------------------------------------------------------

    一个完整的虚方法的例子:

     public class Base
        {

            public virtual void Method()
            {
                Console.WriteLine("Base:Method");
            }
        }


        public class Derived : Base
        {
            public  override void Method()
            {
                Console.WriteLine("Derived:Method");
            }
        }

        class program
        {
            static void Main(string[] args)
            {
                Derived MyDerived = new Derived();
                MyDerived.Method();
                Console.ReadLine();

            }

      }

    输出结果:Derived:Method

    注意:1.可在派生类中以override覆盖此方法
            2.不覆盖也可由对象调用,例如,去掉以下代码:

             public  void Method()
            {
                Console.WriteLine("Derived:Method");
            }
           输出的结果是:Base:Method

    总结:

    抽象方法  
      使用abstract关键字   public   abstract   bool   Withdraw(…);  
      抽象方法是必须被派生类覆写的方法。  
      抽象方法是可以看成是没有实现体的虚方法  
      如果类中包含抽象方法,那么类就必须定义为抽象类,不论是否还包含其它一般方法  
       
      虚方法  
      使用virtual关键字   public   virtual   bool   Withdraw(…);  
      调用虚方法,运行时将确定调用对象是什么类的实例,并调用适当的覆写的方法。  
      虚方法可以有实现体

    若一个实例方法的声明中含有       virtual       修饰符,则称该方法为虚拟方法;一个虚拟方法的实现可以由派生类取代。取代所继承的虚拟方法的实现的过程称为重写该方法;在一个虚拟方法调用中,该调用所涉及的那个实例的运行时类型确定了要被调用的究竟是该方法的哪一个实现。         
                
          虚函数的限制:        
               
          1.虚函数仅适用于有继承关系的类对象,       所以只有类的成员函数才能说明为虚函数.            
          2.静态成员函数不能是虚函数.            
          3.内联函数不能是虚函数.            
          4构造函数不能是虚函数.            
          5.析构函数可以是虚函数.

    虚方法可以被子类override,抽象方法一定要被子类override。  


     

  • 相关阅读:
    ServletContext的应用
    behavior planning——11 create a cost function speed penalty
    behavior planning——10 behaior planning pseudocode
    behavior planning——inputs to transition functions
    卡尔曼滤波——20.卡尔曼预测
    卡尔曼滤波——19.卡尔曼滤波器代码
    卡尔曼滤波——18.预测函数
    卡尔曼滤波——17.高斯移动
    卡尔曼滤波——16.新的均值和方差
    卡尔曼滤波——14.—15分离的高斯分布
  • 原文地址:https://www.cnblogs.com/ly5201314/p/1452805.html
Copyright © 2011-2022 走看看