C++ 代码:

#include <iostream>
#include <string>
using namespace std;
class Parent
{
public:
void fun()
{cout<<"Parent fun"<<endl;}
void fun(int a)
{cout<<"Parent fun int a"<<endl;}
void fun(int a, int b)
{cout<<"Parent fun int a int b"<<endl;}
};
class Child:public Parent
{
public:
void fun()
{cout<<"Child fun"<<endl;}
//void fun(int a)
//{cout<<"Child fun int a"<<endl;}
//void fun(int a, int b)
//{cout<<"Child fun int a int b"<<endl;}
}; int main()
{
Child x;
x.fun();
//x.fun(0); return ;
}

运行结果:

若是将主函数修改为:

int main()
{
Child x;
x.fun();
x.fun(); return ;
}

运行结果:

分析,说明:

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

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

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

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

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

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

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

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

当是虚函数的情况:

#include <iostream>
#include <string>
using namespace std;
class Parent
{
public:
virtual void fun()
{cout<<"Parent fun"<<endl;}
void fun(int a)
{cout<<"Parent fun int a"<<endl;}
void fun(int a, int b)
{cout<<"Parent fun int a int b"<<endl;}
};
class Child:public Parent
{
public:
int fun()
{cout<<"Child fun"<<endl;return ;}
}; int main()
{
Child x;
x.fun(); return ;
}

运行结果:

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

java 部分:

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

class Parent
{
public static void fun()
{System.out.println("Parent fun");}
public static void fun(int a)
{System.out.println("Parent fun int a");}
public static void fun(int a, int b)
{System.out.println("Parent fun int a int b");}
};
class Child extends Parent
{
public static void fun()
{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 class dev
{
public static void main(String []args)
{
Child x=new Child();
x.fun();
x.fun(0);
}
}

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

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

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

即,static 对应相同。

c++  与  java  中的 继承的更多相关文章

  1. 关于Java中的继承和组合的一个错误使用的例子

    [TOC] 关于Java中的继承和组合的一个错误使用的例子 相信绝大多数人都比较熟悉Java中的「继承」和「组合」这两个东西,本篇文章就主要就这两个话题谈论一下.如果我某些地方写的不对,或者比较幼稚, ...

  2. java中的继承与oc中的继承的区别

    为什么要使用继承? 继承的好处: (1)抽取出了重复的代码,使代码更加灵活 (2)建立了类和类之间的联系 继承的缺点: 耦合性太强 OC中的继承 1.OC中不允许子类和父类拥有相同名称的成员变量名:( ...

  3. <Java中的继承和组合之间的联系和区别>

    //Java中的继承和组合之间的联系和区别 //本例是继承 class Animal { private void beat() { System.out.println("心胀跳动...& ...

  4. Java中的继承

    我们在以前的学习中,我们会了C#中的继承,今天我们来了解了解Java中的继承,其实都大同小异啦! 1.语法 修饰符 SubClass extends SuperClass(){ //类定义部分 } e ...

  5. extends:类似于java中的继承特征,extends="struts-default"

    extends:类似于java中的继承特征,extends="struts-default"就是继承struts-default.xml,它里面定义了许多跳转类型.拦截器等一些常用 ...

  6. 关于java中的继承

    我们都知道Java中的继承是复用代码.扩展子类的一种方式,继承使得Java中重复的代码能够被提取出来供子类共用,对于Java程序的性能以及修改和扩展有很大的意义,所以这是一个非常重要的知识点. 那么对 ...

  7. Java中的继承、封装、多态的理解

    Java中的继承.封装.多态 继承的理解: 1.继承是面向对象的三大特征之一,也是实现代码复用的重要手段.Java的继承具有单继承的特点,每个子类只有一个直接父类. 2.Java的继承通过extend ...

  8. 浅析 Java 中的继承和重写

    浅析 Java 中的继承和重写 Java 中的构造方法不能被继承. Java 中 static 修饰的方法可以被继承,但不能被子类重写. Java 中 final 修饰方法不允许被子类重写,但是可以被 ...

  9. java中的继承关系

    1.定义 java中的继承是单一的,一个子类只能拥有一个父类:java中所有类的父类是java.lang.Object,除了这个类之外,每个类只能有一个父类: 而一个父类可以有多个子类,可以被多个子类 ...

  10. java中子类继承父类程序执行顺序

    java中子类继承父类程序执行顺序 FatherTest.java public class FatherTest { private String name; public FatherTest() ...

随机推荐

  1. python 集合清空

    setp = set(["Red", "Green"]) setq = setp.copy() print(setq) setp.clear() print(s ...

  2. 卸载 mysql

    sudo apt-get remove mysql-* dpkg -l |grep ^rc|awk '{print $2}' |sudo xargs dpkg -P 之后会跳出一个弹框点击“是”就行了

  3. python 操作浏览器打开指定网页

    #! /usr/bin/env python # encoding=utf8 import webbrowser import time webbrowser.open("http://ww ...

  4. 精通移动app测试实战

  5. Meta referrer标签的简要介绍

    在某些情况下,出于一些原因,网站想要控制页面发送给 server 的 referer 信息的情况下,可以使用这一 referer metadata 参数. 参数 referer 的 metedata ...

  6. 《剑指offer》第二十四题(反转链表)

    // 面试题24:反转链表 // 题目:定义一个函数,输入一个链表的头结点,反转该链表并输出反转后链表的 // 头结点. #include <iostream> #include &quo ...

  7. 《剑指offer》第十四题(剪绳子)

    // 面试题:剪绳子 // 题目:给你一根长度为n绳子,请把绳子剪成m段(m.n都是整数,n>1并且m≥1). // 每段的绳子的长度记为k[0].k[1].…….k[m].k[0]*k[1]* ...

  8. es6模块 nodejs模块和 typescript模块

    es6模块 import和export nodejs模块 require和module.exports typescript模块 module和export

  9. HDU-3480 Division (四边形不等式优化DP)

    题目大意:将n个数分成m组,将每组的最大值与最小值的平方差加起来,求最小和. 题目分析:先对数排序.定义状态dp(i,j)表示前 j 个数分成 i 组得到的最小和,则状态转移方程为dp(i,j)=mi ...

  10. 手动安装Silverlight 4 Tools for Visual Studio 2010

    手动安装吧,将Silverlight 4 Tools for Visual Studio 2010.exe改成rar文件,解压缩,按照下面的步骤安装: 1.silverlight_developer. ...