zoukankan      html  css  js  c++  java
  • override 和 重载的区别? Kevin

    简单答案:
    1.
    父类:public virtual string ToString(){return "a";}
    子类:public override string ToString(){return "b";}
    2.
    同一类中或父子关系类中皆可:
    public string ToString(){return "a";}
    public string ToString(int id){return id.ToString();}

    override是用于重写基类的虚方法,这样在派生类中提供一个新的方法

    重载是提供了一种机制, 相同函数名通过不同的返回值类型以及参数来表来区分的机制

    ===============================================
    很本质的区别就是看函数特征:覆写(Override)的两个函数的函数特征相同,重载(Overload)的两个函数的函数名虽然相同,但函数特征不同。 
    函数特征包括函数名,参数的类型和个数。 
    Override 是在继承的时候,如果你写的函数与要继承的函数函数特征相同,那么,加上这个关键字,在使用这个子类的这个函数的时候就看不见父类(或超类)的函数了,它被覆盖掉了。 
    比如:Derived继承了Base,Base里面有void A(int a) 
    那么如果你Derived里面觉得A写得不好或不适合这个类,你想重新再写一遍A里的代码,那么就写override void A(int a)这样,原来的那个函数就被你新写的这个覆盖掉了。 
    Overload 是重载,就是说函数名相同,函数特征不同,系统会根据你提供的参数来调相应的函数。 
    比如:void A(int a)和void A(int a,int b) 
    如果你用的是A(1)那么调的是第一个,如果是A(1,1)那么调的是第二个。
    =================================================

    1. override
    -----------
    使用 override 修饰符来修改方法、属性、索引器或事件。重写方法提供从基类继承的成员的新实现。由重写声明重写的方法称为重写基方法。重写基方法必须与重写方法具有相同的签名。

    不能重写非虚方法或静态方法。重写基方法必须是虚拟的、抽象的或重写的。

    也就是说,用 override 修饰符重写的基类中的方法必须是 virtual, abstract 或 override 方法。



    2. 重载
    -------
    当类包含两个名称相同但签名不同的方法时发生方法重载。

    使用重载方法的指南:
    a. 用方法重载来提供在语义上完成相同功能的不同方法。
    b. 使用方法重载而不是允许默认参数。默认参数的版本控制性能不好,因此公共语言规范(CLS)中不允许使用默认参数。
    c. 正确使用默认值。在一个重载方法系列中,复杂方法应当使用参数名来指示从简单方法中假定的默认状态发生的更改。
    d. 对方法参数使用一致的排序和命名模式。提供一组重载方法,这组重载方法带有递增数目的参数,以使开发人员可以指定想要的级别的信息,这种情况很常见。您指定的参数越多,开发人员就可指定得越详细。
    e. 如果必须提供重写方法的能力,请仅使最完整的重载是虚拟的并根据它来定义其他操作。
    // 下面具体解释一下这种模式,只有最后一个方法(参数最完整的方法)是虚方法,在继承了这个类的子类中只要重写(override)这个方法就行了。

    public class SampleClass
    {
       private string myString;

       public MyClass(string str)
       {
          this.myString = str;
       }

       public int IndexOf(string s)
       {
          return IndexOf (s, 0);
       }

       public int IndexOf(string s, int startIndex)
       {
          return IndexOf(s, startIndex, myString.Length - startIndex );
       }

       public virtual int IndexOf(string s, int startIndex, int count)
       {
          return myString.IndexOf(s, startIndex, count);
       }
    }

  • 相关阅读:
    107. Binary Tree Level Order Traversal II
    103. Binary Tree Zigzag Level Order Traversal
    102. Binary Tree Level Order Traversal
    690. Employee Importance
    1723. Find Minimum Time to Finish All Jobs
    LeetCode 329 矩阵中最长增长路径
    7.2 物理内存管理
    LeetCode 面试题 特定深度节点链表
    LeetCode 100 相同的树
    npm安装包命令详解,dependencies与devDependencies实际区别
  • 原文地址:https://www.cnblogs.com/kfx2007/p/2639611.html
Copyright © 2011-2022 走看看