封装,继承,多态是面向对象的三大特性。每一种特性,都有很多细节知识点。在这里,我们主要介绍一下继承中的同名隐藏和赋值兼容规则。
同名隐藏:只要子类中的函数名与父类函数名相同,子类中的函数将会隐藏所有父类和子类同名的函数,只要名字相同就可以,不管参数列表。注意与函数重载的区别。
#include<iostream>
#include<stdio.h>
#include<string>
using namespace std;
class A
{
public:
A() {}
~A() {}
void setStr(string str)
{
cout<<"class A"<<endl;
}
};
class B : public A
{
public:
B() {}
~B() {}
void setStr(char ch)
{
cout<<"class B:"<<"char"<<endl;
}
void setStr(double d)
{
cout<<"class B:"<<"double"<<endl;
}
};
int main()
{
B b;
b.setStr('A'); // 1
b.setStr(12.120); //2
b.setStr("helloWorld"); //3
b.A::setStr("helloWorld"); //4
return 0;
}
在上述代码中,标号1和2 的行 会按照函数重载的规则正确运行。 标号3则出错。 因为 父类A中的函数被隐藏,在子类B中没有可以处理string类型的相应函数。
如果想要使用父类A中的函数,则可以按照 标号4 的方式。
赋值兼容规则:
概念:在任何需要基类对象的地方都可以使用公有的派生类对象来替代。
在共有继承方式下,赋值兼容规则规定:
(1)派生类对象可以赋值给基类的对象,这个时候派生类的对象中,从对应基类中继承来的隐藏部分赋值给基类对象
(2)派生类对象的地址值可以赋值给基类的对象指针,但只能通过这个指针访问派生类中由基类继承来的隐藏对象,不能访问派生类中的新成员
(3)派生类对象可以用来给基类对象引用初始化,但这个引用只能包含派生类对象中由基类继承来的隐藏对象
使用上述规则,必须注意两点:
(1)必须是公有继承
(2)上述条件不可逆