java派生类的同名覆盖_c++  与  java  中的 继承

C++ 代码:

#include #include

using namespacestd;classParent

{public:voidfun()

{cout<

{cout<

{cout<

};class Child:publicParent

{public:voidfun()

{cout<

};intmain()

{

Child x;

x.fun();//x.fun(0);

return 0;

}

运行结果:

1c136e2657782cef132a1ce394303ae4.png

若是将主函数修改为:

intmain()

{

Child x;

x.fun();

x.fun(0);return 0;

}

运行结果:

80714838e7cc9ee977bfe32b8d973f17.png

分析,说明:

在c++中,重载不会发生在基类与派生类之间,重载 制发生在同一类中!当基类和派生类中存在同名函数时,无论同名函数的形参个数或者类型是否相同,派生类中的同名函数都会将基类中的同名函数隐藏(将在下边说明隐藏)掉,而不会是重载关系。这时,当你通过派生类对象调用该同名函数时,只能访问派生类的该函数,如果硬要访问基类的该函数,则需要在函数名前加上类作用域!

如果将派生类中的同名函数 设为 static 静态, 运行效果如上不变。

class Child:publicParent

{public:static voidfun()

{cout<

};

如果将父类中的同名函数 设为 static 静态, 运行效果如上仍不变。

classParent

{public:static voidfun()

{cout<

{cout<

{cout<

};

C++ 中 同名函数是否为 静态 static  , 不影响 继承中的覆盖 关系。总之, c++中的 重载只发生在同一类中, 也就是说 C++的继承存在隐藏。

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

若是 子类中的同名函数 返回值不同,如下,仍然会覆盖父类同名函数,即c++继承中的 覆盖及其隐藏 只和 函数名 相同与否 有关。

1c6805b95fbfef4129f98fefe643f50c.png

4d5b880aa3f6a6431a894bc8949c367b.png

5a9ee0c21a9a67acf1b41e11f51a1863.png

78d8e55cdabed3ae8c6e59201793f5d8.png

当是虚函数的情况:

#include #include

using namespacestd;classParent

{public:virtual voidfun()

{cout<

{cout<

{cout<

};class Child:publicParent

{public:intfun()

{cout<

};intmain()

{

Child x;

x.fun();

return 0;

}

运行结果:

499e58a870b46dcd3803ed3bbb9f57e0.png

对于虚函数(用virtual修饰的),如果基类中有一个虚函数,派生类中同样有一个同名同参的函数(那么该函数将自动虚化), 那么其返回值一定要和基类的虚函数的返回值相同!否则 覆盖失败,编译不通过,隐藏失败!

java 部分:

如上述代码所示。而在java中子类会将父类中的方法继承过来,子类中同名方法会和父类中的同名方法要么是重载关系,要么是覆盖关系,要么就错误(比如同名同参却是不同的返回类型!)

classParent

{public static voidfun()

{System.out.println("Parent fun");}public static void fun(inta)

{System.out.println("Parent fun int a");}public static void fun(int a, intb)

{System.out.println("Parent fun int a int b");}

};class Child extendsParent

{public static voidfun()

{System.out.println("Child fun");}//public void fun(int a)//{System.out.println("Child fun int a");}//public void fun(int a, int b)//{System.out.println("Child fun int a int b");}

};public classdev

{public static voidmain(String []args)

{

Child x=newChild();

x.fun();

x.fun(0);

}

}

f84d9a23e639edd0fbead06ee592ff2b.png

若是,去掉 子类中 的 static ,  无法编译, 即 java 继承中的覆盖 要求 区分 static, 即static 同名函数 覆盖父类的static 同名函数。

654b2ade60194f61a51bcae9f9b03d1e.png

ee06daf2c636f761acd1993d4f75b41d.png

如果父类 同名函数 无static ,   子类同名函数有 static, 即

67628dd0d3060e10bb3fb4258a6a2e2c.png

ffd2e455d6bca2a3c6d02ac4cd194732.png

在java中, 非静态方法只能由(或被)非静态方法覆盖! 静态方法只能由(或被)静态方法覆盖!

即,static 对应相同。

原文:http://www.cnblogs.com/devilmaycry812839668/p/6358431.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值