#include<iostream>
using namespace std;
//father1和subfromfather1为了说明:定义 基类* 指针=new 派生类 时,已被复写的函数如果是虚函数则调用派生类实现,
//其余正常调用基类实现
class father1{
public:
virtual void fun1_1(){
cout << "from father1 fun1_1 virtual" << endl;
}
virtual int fun1_2(){
cout << "from father1 fun1_2 virtual" << endl;
return int();
}
};
class subfromfather1 :public father1{
virtual void fun1_1(){
cout << "from subfromfather1 fun1_1 virtual" << endl;
}
virtual void subfun1_2(){
cout << "from subfromfather1 fun1_1 virtual" << endl;
}
};
//father2和subfromfather2为了说明:抽象类中的纯虚函数必须在派生类中实现,定义 基类* 指针=new 派生类 时,
//未被复写的成员函数正常调用
class father2{
public:
void fun2_1(){
cout << "from father2 fun2_1 normal" << endl;
}
virtual int fun2_2(){
cout << "from father2 fun2_2 virtual" << endl;
return int();
}
virtual int fun2_3() = 0;
};
class subfromfather2 :public father2{
//尝试引去该实现会提示报错,纯虚函数未实现
virtual int fun2_3(){
cout << "from subfromfather2 fun2_3 virtual" << endl;
return int();
}
};
//father3和subfromfather3为了说明:定义 基类* 指针=new 派生类 时,基类中非虚或者纯虚成员函数即使存在复写,
//也不会调用派生类实现,因为不存在虚函数表,无法映射
class father3{
public:
void fun3_1(){
cout << "from father3 fun3_1 normal" << endl;
}
int fun3_2(){
cout << "from father3 fun3_2 normal" << endl;
return int();
}
};
class subfromfather3 :public father3{
void fun3_1(){
cout << "from subfromfather3 fun3_1 normal" << endl;
}
void subfun3_2(){
cout << "from subfromfather3 subfun3_2 normal" << endl;
}
};
int main(){
father1* ptr1; //father1类型指针 说明了该指针可以指向father1或者它的派生类
//上句代码仅仅是声明指针,father1* 可以看作一个整体,是指针类型,
//可以输出sizeof(),你会发现不管什么类型的指针(比如类指针或者int指针)输出都是4.
//这是个野指针,会指向一个不确定的地址,所以是不能用的,尝试把下面这句去掉注释,会报错,提示未初始化
//所以正常要避免出现野指针这种情况,对于野指针进行操作,即对未知地址操作这是很危险的,可能存在数据覆盖等问题
//为了避免这种情况,可以先 xxx* ptr=NULL; 指向0x00000000位置,至少避免了未知地址的风险
//即使上一句改成father1* ptr1=NULL; 这时候去掉下面这句注释仍然存在错误,毕竟0x00000000这个地址是不对的,
//所以还是要指向正确地址的
//这里再插一句指针内存释放的问题,指向的地址可以用new-delete释放,然后处于安全考虑让指针指向NULL,
//指针本身内存释放需要用代码块,出了代码块自动释放
//ptr1->fun1_1();
ptr1 = new subfromfather1; //意思是该指针指向subfromfather1
ptr1->fun1_1();
ptr1->fun1_2();
father2* ptr2;
ptr2 = new subfromfather2;
ptr2->fun2_1();
ptr2->fun2_2();
ptr2->fun2_3();
father3* ptr3;
ptr3 = new subfromfather3;
ptr3->fun3_1();
ptr3->fun3_2();
char temp = getchar();
return 0;
}