c 派生和java继承_c++中继承和java中继承的对比

java中:

classParent{public void test(inta){

System.out.println("Parent:" +a);

System.out.println(this.getClass().getName());

}

}class Child extendsParent{public void test(int a, intb){

System.out.println("Child:" + a + " " +b);

}

}public classParentAndChild {public static voidmain(String[] args) {//TODO Auto-generated method stub

Child ch = newChild();

ch.test(5);//也就是说在java中子类会将父类的方法继承过来,没有隐藏,对于//同名同参的是覆盖,对于同名不同参的是重载

}

}

/*

输出结果:

Parent:5

testone.Child

*/

c++中:

#include

using namespacestd;classParent{public:

static void run(){

cout<

}void test(inta){

cout<

}void test(int a, intb){

cout<

}

};class Child : publicParent{public:

/* static void run(){//这两种写法都是正确的

cout<

}

void run(){

cout<

}

*/

void test(int a, intb){

cout<

}

};intmain(){

Child ch;

ch.Parent::test(5, 4);//通过这种调用可以访问父类的同名函数//ch.test(4);//错误:派生类和基类中存在同名的函数,基类中的该函数被隐藏,也就是找不到//应该写成ch.Parent::test(4);

return 0;

}

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

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值