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()
转成基类的时候调用了拷贝构造