1.成员函数被重载的特征:
(1)相同的范围(在同一个类中);
(2)函数名字相同;
(3)参数不同;
(4)virtual关键字可有可无。
2.覆盖是指派生函数覆盖基类函数
(1)不同的范围(分别位于派生类和基类);
(2)函数名相同;
(3)参数相同;
(4)基类函数必须有virtual关键字。
3.这里“隐藏”是指派生类的函数屏蔽了与其同名的基类函数
1.Java中的重载和C++没什么区别。就是一个类内部同名不同参的函数。
2.Java的覆盖和C++有所不同。
(1)C++中的覆盖仅对于virtual类成员函数而言;Java中不存在virtual关键字,所有的类成员函数都可以认为是C++中的virtual函数。当然静态成员函数是不能被覆盖的,因为不是运行时和类实例匹配,而是在编译时和类实例匹配的。
(2)Java中有final关键字,final修饰的函数是不能被覆盖的,即使你在子类中写了覆盖的函数,也不会被调用。
(3)在C++中虚函数的覆盖与访问控制无关,public的虚函数可以被子类中private的虚函数覆盖。而Java中明确表明私有函数不能被覆盖,子类的函数并不能覆盖父类的同名函数。
(4)由于C++中存在非常随意的强制转换,特别是类指针之间的转换,所以可以采用许多手段访问一个类的虚函数,包括私有虚函数。Java中不存在指针的随意强制转化,所以不存在这个问题。
(5)可以大致这样认为,Java中的所有公有成员函数 都可以是为C++中的共有虚函数,Java中的私有函数都可以是为C++中的私有非虚函数。
(6)多说一句,Java 中的abstract函数可不是C++中的virtual关键字,而是类似于C++中的纯虚函数。
3.Java中没有隐藏规则(有的是变量的隐藏)
(1)在Java中不存在隐藏规则,如果是上述的情况a,那么子类可以调用基类的同名函数;如果是情况b,则是覆盖。
Java中方法覆盖满足的要求:
a.覆盖方法与被覆盖方法的返回值,方法名,参数要完全一致;
b.覆盖方法的访问级别不能低于被覆盖的函数的访问级别;
c.覆盖方法不能比被覆盖函数抛出更多的受检查异常。
为什么java中没有隐藏规则?