对比C++和java在继承方面对方法的不同处理

对比C++和java在继承方面对方法的不同处理

1.C++方法隐藏,java方法重载

java

class A{
    public void f() {
        System.out.println("A::f()");
    }
}

class B extends A{

    public void f(int a) {
        System.out.println("B::f()");
    }
}

public class Main{

    public static void main(String[] args) {
        B obj = new B();
        obj.f();
    }
}

输出:

A::f()

对于java方法,如果派生类出现同名函数,但函数特征标不同,则会认定为重载

C++

class A {
public:
    void f() {
        cout << "A::f()" << endl;
    }
};

class B : public A{
public:
    void f(int a) {
        cout << "B::f()" << endl;
    }
};


int main() {

    B objb;
    objb.f();
    return 0;
}

报错:B::f函数不接受0个参数

可见,C++派生类的同名方法会隐藏基类的方法

基类中如果有重载方法,如果派生类要重定义,则需要重定义所有的基类重载方法

2.java所有方法都可以动态绑定(C++中的虚特性)

java

class A{
    public void f() {
        System.out.println("A::f()");
    }
}

class B extends A{

    public void f() {
        System.out.println("B::f()");
    }
}


public class Main{

    public static void main(String[] args) {
        A obj = new A();
        obj.f();
        obj = new B();
        obj.f();
    }
}

输出:

A::f()
B::f()

C++

class A {
public:
    A() {
    }
    void f() {
        cout << "A::f()" << endl;
    }
};

class B : public A{
public:
    B() {
    }
    void f(){
        cout << "B::f()" << endl;
    }
};


int main() {

    A *pobj = new A();
    pobj->f();
    delete pobj;

    pobj = new B();
    pobj->f();
    delete pobj;

    return 0;
}

输出:

A::f()
A::f()

由于f是非虚函数,采用静态联编,所以,将指针pobj指向的对象都当作类A的对象,调用时,调用A::f

将C++中基类方法虚化(派生类自动虚化)

仅修改一处

class A {
public:
    A() {

    }
    virtual void f() {
        cout << "A::f()" << endl;
    }
};

输出:

A::f()
B::f()

猜你喜欢

转载自blog.csdn.net/qq2071114140/article/details/89311672
今日推荐