在c++里面,基类和继承类有三层的关系。
1:重载,对重载来说,必须是相同的作用域,函数名相同,函数的参数列表不同。
2:隐藏。所谓隐藏就是派生类把基类的同名的函数给隐藏了。在派生类对象调用此
函数的时候只能调用派生类的函数。基类的函数被隐藏了。
3:覆盖。在基类的函数名前面加上virtual(即虚拟的)时,此函数就成了虚函数。
如果在派生类里面,有同名,同参数的,同返回值时,此函数也就成了虚函数。
这就是覆盖。
例如:
#include<iostream>
using namespace std;
class A
{public:
A(int val = 12){}
virtual void show()
{
cout << "A is show()" << endl;
cout << ma <<endl;
}
protected:
int ma;
};
class B:public A
{
public:
B(int size = 10) :mb(size), A(size){}
void show()
{
cout << "B is show()" << endl;
cout << mb << endl;
}
private:
int mb;
};
int main()
{
B b;
A *p =&b;
p->show();
return 0;
}
对于A类和B类的内存布局是:
一些问题?
1:在那些情况下会发生多态那?
只要是使用指针或者引用,而且调用的函数是虚函数,就可以发生多态。
2:vfptr可以交换,而且vfptable是在编译的情况下产生的,运行的时期加载到.rodata段。
3:函数能否调用,是在编译阶段看指针类型里面函数的修饰符。