快速理解C++中函数的重载,隐藏,重写

重载:在同一个作用域内;函数名相同,参数列表不同(参数个数不同,或者参数类型不同,或者参数个数和参数类型都不同),返回值类型可相同也可不同;这种情况叫做c++的重载,C语言不支持重载
特征:
1.同一个作用域
2.函数名相同
3.参数不同(类型,个数,顺序)
4.Virtual关键字可有可无
举例:输出运算符重载

c++函数重载是一种静态多态(又叫做静态联编,静态绑定,静态决议)

覆盖/重写:指派生类函数覆盖基类函数
特征:
1.不同的范围(分别位于派生类和基类)
2.函数名相同
3.参数相同
4.基类函数必须有关键字virtual

有两种情况:

1.就是说子类中的虚函数和父类中的虚函数,函数名,参数个数,参数类型,返回值类型都相同;这种情况下子类的这个虚函数重写的父类中的虚函数,构成了重写;

2、协变—是说子类中的虚函数和父类中的虚函数,函数名,参数个数,参数类型都相同,只是返回值类型不同;父类的虚函数返回父类的指针或者引用,子类虚函数返回子类的指针或者引用;这种情况下子类的这个虚函数也重写了父类中的虚函数,也构成了重写;——我们把这种特殊的情况叫做协变

为什么重写?

  • .在子类中重写了父类的虚函数,那么子类对象调用该重写函数,调用到的是子类内部重写的虚函数,而并不是从父类继承下来的虚函数;(这其实就是动态多态的实现);

  • 2.在子类中重写了父类的虚函数,如果用一个父类的指针(或引用)指向(或引用)子类对象,那么这个父类的指针或用引用调用该重写的虚函数,调用的是子类的虚函数;相反,如果用一个父类的指针(或引用)指向(或引用)父类的对象,那么这个父类的指针或用引用调用该重写的虚函数,调用的是父类的虚函数

隐藏/重定义:指派生类函数屏蔽了与其同名的基类函数
两条规则:
1.如果派生类与基类函数名相同,参数不同,此时无论有无关键字virtual,基类函数都将被隐藏
2.如果派生类与基类函数名相同,参数相同,但是基类函数没有virtual,此时,基类函数都将被隐藏

重定义的不光是类的成员函数,还可以是类的成员变量

如果在父类和子类中有相同名字的成员;那么在子类中,会将父类的成员隐藏;

无论在子类的内部或者外部(通过子类成员)访问该成员,全都是访问子类的同名成员;

如果在子类内部或者外部(通过子类成员)访问同名的成员函数,则需要根据函数调用的规则来调用子类的同名成员函数,否则调用失败;

PS:派生类函数隐藏了基类函数的情况,应指针进行访问函数,取决于指针类型,如果是派生类指针,则调用派
生类的该函数,反之调用基类的函数

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值