多态

class A
{
public:
void aaa()
{
printf("aaa");
}
virtual int aaa(int a)
{
printf("int aaa");
return 0;
}


};
class B :public A
{
public:
void aaa()
{
printf("bbb");
}
/*virtual void aaa()
{
printf("bbb"); //测试父类中普通函数 与 子类中虚函数 
}*/
};


int _tmain(int argc, _TCHAR* argv[])
{
A* a;
B b;
a = &b;



/*
A aa;
long** p = (long**)&aa;
FUN fun = (FUN)p[0][0];
fun();*/


/*long**p1 = (long**)&b;
fun = (FUN)p1[0][0];
fun();
fun = (FUN)p1[0][1];
fun();*/

a->aaa(); //这里是动态
//b.aaa();//这里是重载
return 0; //他们都是从写了aaa函数,实现的是子类b的方法 就是同类同对象调用的时候 不管是虚还是普通函数 都跟重载是一样的
}


//父类中是虚函数 子类中是普通函数 当继承后子类相同函数名会自动变成虚函数 既然变成了虚函数 那么调用的子类对象指向的函数

//当父类中是普通函数 子类中是虚函数 继承后子类相同函数也会变成普通函数,那么调用的就是父类类型指向的函数

//

//普通函数不在虚表中

所以下图就出错了

 

 多态

 

 

 

 多态多态多态

 

 func中又调用了Serialize()

 多态

 转成基类的时候调用了拷贝构造

 多态

 

上一篇:SpringMVC笔记之Ajax


下一篇:linux安装python