【java&c++】父子类中同名函数的覆盖问题

java和c++两门语言对于父子类中同名函数具有不同的处理方式。

先上两段代码:

C++:

class Basic
{
public:
    void test(string i){
        cout << "basic str" <<endl;
    }
    void test(int i){
        cout << "basic" <<endl;
    }

};

class Senior : public Basic
{

public:
    void test(long i){
        cout << "senior 1" <<endl;
    }

};

int main(int argc, const char * argv[]) {
    // insert code here...
    std::cout << "Hello, World!\n";

    Senior ps;
    ps.test(23);
    string str("c");
    ps.test(str);
    return 0;
}

//输出结果编译错误,提示No viable conversion from ‘string‘ (aka ‘basic_string<char, char_traits<char>, allocator<char> >‘) to ‘long‘

修改标红的代码--> ps.Basic::test(str) 则可以编译成功,并输出预期的结果

senior 1

basic str

public class Basic{
    public int testException(int val) {
        try{
            int j = 3/1;
            return j;
        }
        catch(Exception e){
            return -1;
        }
    }
    public String testException(String val) {
        try{
            return new String("ac");
        }
        catch(Exception e){
            return new String("bc");
        }
    }

};

public class Senior extends Basic{
    public Long testException(Long val) {
        try{
            return  (long) 9;
        }
        catch(Exception e){
            return (long) 7;
        }
    }
}

public static void main(String args[]) throws InstantiationException, IllegalAccessException, SecurityException, Exception{
    // 向控制台输出信息

    Senior ba = new Senior();
    System.out.println("basic:" + ba.testException(2));
    System.out.println("basic:" + ba.testException("123"));
  }
}

输出结果

basic:3

basic:ac
 
 

比较这个例子中的不同,原因是java语言中父类和子类的同名函数做的是重载处理,而C++中是隐藏父类中的函数,如果需要调用父类中同名函数,需要显式指定调用(通过class::funtion_name)。

时间: 2024-10-26 00:09:16

【java&c++】父子类中同名函数的覆盖问题的相关文章

判断在类中某个函数(也可以是变量或类型)是否存在

一,判断在类中某个函数(也可以是变量或类型)是否存在 template<typename T> struct xxxx_detector { template<typename P,void (P::*)(void)> struct detector{}; template<typename P> static char func(detector<P,&P::init>*); template<typename P> static lo

java的Object类中hashCode()和equals()方法-----转载

JAVA代码:    public static void main(String[] args)    {        Object obj1 = new Object();        Object obj2= new Object();        Object obj3 = obj2;        System.out.println("obj1==obj2 ?"+obj1.equals(obj2));        System.out.println("o

java.util.Stack类中的peek()方法

java.util.stack类中常用的几个方法:isEmpty(),add(),remove(),contains()等各种方法都不难,但需要注意的是peek()这个方法. peek()查看栈顶的对象而不移除它. import java.util.Stack; public class MyStack1 { private Stack<Integer> stackData; private Stack<Integer> stackMin; public MyStack1(){ t

类语法规则与类中的函数

类语法 1.关键字class 2.class 类名 类名中不要写括号 3.类名规范:字母.数字.下划线组成,不能以数字开头:驼峰命名法,每个单词首字母大写 4.类属性:放在类中的变量值 调用属性:实例.属性名 5.类方法:类中的函数 调用方法:实例.方法名()---针对实例方法 类属性和类方法都不是类中必须的结构,但是一般都会有,这是类存在的意义 6.类里面的方法分3种: 1)实例方法:这个方法只能实例来调用 必须带有self参数; 括号里的self指的是实例本身,调用该函数时会自动传入实例;

java涉及父子类的异常

java中的异常涉及到父子类的问题,可以归纳为一句话:子类的构造函数抛出的异常必须包含父类的异常,子类的方法可以选择抛出“范围小于等于”父类的异常或不抛出异常. 1. 为什么构造函数必须抛出包含父类的异常? 在<thingking in java>中有这么一段话: 异常限制:当覆盖方法时,只能抛出在基类方法的异常说明中列出的那些异常 异常限制对构造器不起作用,你会发现StormyInning的构造器可以抛出任何异常,而不必理会基类构造函数所抛出的异常.然而因为必须构造函数必须以这样或那样的方式

23.C++- 继承的多种方式、显示调用父类构造函数、父子之间的同名函数、virtual虚函数

在C++中,继承方式共有3种: public继承 -指父类的成员(变量和函数)访问级别,在子类中保持不变 private继承 -指父类的成员,在子类中变为private私有成员. -也就是说子类无法访问父类的所有成员 protected继承 -指父类的public成员 ,在子类中变为protected保护成员,其它成员级别保持不变 <span "="" src="https://images2018.cnblogs.com/blog/1182576/20180

C++ 类中成员函数分析

概述之前对成员变量的分布进行了整理,今天就对成员函数进行整理. 1.非静态成员函数C++的设计准则之一就是:非静态成员函数至少和一般的非成员函数的执行效率相同. 为了实现上衣准则,编译器会对非静态成员函数进行改进,先看下面的例子: float func(const Point3d* _this) { .... } float Point3d::func() const { .... }123编译器对会Point3d::func()做下面三个步骤的操作: 1.改写函数func以安插一个额外的参数到

回调同一个类中的函数

写了一个类处理好友,其中有一个方法用来同步好友,而这个方法中需要从微博传来的关注列表和粉丝列表中,找到互相关注的用户,记录一下经验,主要还是关于回调函数. 按照我最初的理解,这样写就可以了 private function getMutualFromSina ($focusList) { return array_filter($focusList, "filterSinaList"); } private function filterSinaList ($value) { retu

cocos2dx lua 绑定之二:手动绑定自定义类中的函数

cococs2dx 3.13.1 + vs2013 + win10 1.首先按照<cocos2dx lua 绑定之一:自动绑定自定义类>绑定Student类 2.在Student类中增加一个用于测试手动绑定的函数manual_call ①Student.h中增加函数 //手动绑定调用函数 void manual_call(); ②Student.cpp中增加函数实现 //和自动绑定相比,只增加了这个函数 void Student::manual_call() { std::cout <&