• c++中继承和java中继承的对比


    java中:

    class Parent{
        public void test(int a){
            System.out.println("Parent:" + a);
            System.out.println(this.getClass().getName());
        }
    }
    
    class Child extends Parent{
        public void test(int a, int b){
            System.out.println("Child:" + a + " " + b);
        }
    }
    
    public class ParentAndChild {
    
        public static void main(String[] args) {
            // TODO Auto-generated method stub
            Child ch = new Child();
            ch.test(5);//也就是说在java中子类会将父类的方法继承过来,没有隐藏,对于
                       //同名同参的是覆盖,对于同名不同参的是重载
        }
    
    }
    /*
    输出结果:

         Parent:5
         testone.Child

    */

    c++中:

    #include<iostream>
    using namespace std;
    
    class Parent{
        public:

         static void run(){
            cout<<"Parent"<<endl;
         }
    void test(int a){ cout<<"Parent:"<<a<<endl; } void test(int a, int b){ cout<<"Parent:"<<a<<" "<<b<<endl; } }; class Child : public Parent{ public:

              /* static void run(){//这两种写法都是正确的
            cout<<"Child"<<endl;
          }

          void run(){
            cout<<"Child"<<endl;
          }

          */

    void test(int a, int b){
                cout<<"Child:"<<a<<" "<<b<<endl;
            }
    };
    
    int main(){
        Child ch;
        ch.Parent::test(5, 4);//通过这种调用可以访问父类的同名函数 
        //ch.test(4); //错误:派生类和基类中存在同名的函数,基类中的该函数被隐藏,也就是找不到
                      //应该写成ch.Parent::test(4); 
        return 0;
    } 

    区别:在c++中,重载不会发生在基类与派生类之间!当基类和派生类中存在同名函数时,无论同名函数的形参个数或者类型是否相同,派生类中的同名函数都会将基类中的同名函数隐藏(将在下边说明隐藏)掉,而不会是重载关系。这时,当你通过派生类对象调用该同名函数时,只能访问派生类的该函数,如果硬要访问基类的该函数,则需要在函数名前加上类作用域!如上述代码所示。而在java中子类会将父类中的方法继承过来,子类中同名方法会和父类中的同名方法要么是重载关系,要么是覆盖关系,要么就错误(比如同名同参却是不同的返回类型!)

    在c++中隐藏只能出现在基类和派生类之间,而不能发生在同一个类内(否则会引起编译器出现二义性)。当基类和派生类中存在同名函数时,无论同名函数的形参个数或者类型是否相同,派生类中的同名函数都会将基类中的同名函数(这个函数不论是静态或者是非静态都可以,如上述例子)隐藏掉,而不会是重载关系。这时,当你通过派生类对象调用该同名函数时,只能访问派生类的该函数,如果硬要访问基类的该函数,则需要在函数名前加上类作用域!对于虚函数(用virtual修饰的),如果基类中有一个虚函数,派生类中同样有一个同名同参的函数(那么该函数将自动虚化), 那么其返回值一定要和基类的虚函数的返回值相同!否则隐藏失败!

    但是在java中请记住这样的原则:非静态方法只能由(或被)非静态方法覆盖!静态方法只能由(或被)非静态方法覆盖!抽象方法必须在具体类中被覆盖!最终方法(带关   键字final的方法)不能被覆盖!

  • 相关阅读:
    集合——iterator迭代器
    集合——顶层collection接口(单列集合)
    集合——集合框架
    构造方法
    接口作为方法的参数或返回值——List接口
    接口作为成员变量——实现类和匿名内部类和匿名对象
    距离和相似度度量
    Kmeans算法与KNN算法的区别
    linux命令
    MapReduce初级案例
  • 原文地址:https://www.cnblogs.com/hujunzheng/p/3969166.html
Copyright © 2020-2023  润新知