#include <iostream>
using namespace std;
class A
{
public:
A()
{
cout<<"A"<<endl;
}
void virtual print()
{
cout<<"A print"<<endl;
}
virtual ~A()
{
cout<<"~A"<<endl;
}
int i;
};
class B:public A
{
public:
B()
{
cout<<"B"<<endl;
}
void print()
{
cout<<"B print"<<endl;
}
virtual ~B()
{
cout<<"~B"<<endl;
}
};
class C:public B
{
public:
C()
{
cout<<"C"<<endl;
}
void print()
{
cout<<"C print"<<endl;
}
virtual ~C()
{
cout<<"~C"<<endl;
}
};
void print(A &a)
{
a.print();
}
void print2(A *pa)
{
pa->print();
}
void print3(A a)
{
a.print();
}
int main()
{
A a;
B b;
C c;
A *pa = new A;
delete pa;
c.i = 3;
a = c;
cout<< a.i << endl;
cout<<"*******对象输出******"<<endl;
a.print();
b.print();
c.print();
cout<<"*******改为父类的引用输出******"<<endl;
print(a);
print(b);
print(c);
cout<<"*******改为父类的指针输出******"<<endl;
print2(&a);
print2(&b);
print2(&c);
cout<<"*******改为父类的拷贝输出******"<<endl;
print3(a);
print3(b);
print3(c);
return 0;
}
/*一、虚函数时,对象生成,有个虚表指针地址,在类的首地址上,这个地址记录对象对应的类的虚函数表地址,所以对象的指针改成其它类型,但是虚表指针的值没变,依然执行对象对应的类型的虚函数
A
A
B
A
B
C
A
~A
3
*******对象输出******
A print
B print
C print
*******改为父类的引用输出******
A print
B print
C print
*******改为父类的指针输出******
A print
B print
C print
*******改为父类的拷贝输出******
A print
~A
A print
~A
A print
~A
*/
/*二、非虚函数时
A
A
B
A
B
C
A
~A
3
*******对象输出******
A print
B print
C print
*******改为父类的引用输出******
A print
A print
A print
*******改为父类的指针输出******
A print
A print
A print
*******改为父类的拷贝输出******
A print
~A
A print
~A
A print
~A
*/
/*三、当对象带入函数发生拷贝时,虚函数表指针地址的值不拷贝,只拷贝变量的值;不会执行构造函数,但会执行析构函数*/
/*四、对象赐值时,只对变量赐值,不会复制虚函数表指针地址的值*/
using namespace std;
class A
{
public:
A()
{
cout<<"A"<<endl;
}
void virtual print()
{
cout<<"A print"<<endl;
}
virtual ~A()
{
cout<<"~A"<<endl;
}
int i;
};
class B:public A
{
public:
B()
{
cout<<"B"<<endl;
}
void print()
{
cout<<"B print"<<endl;
}
virtual ~B()
{
cout<<"~B"<<endl;
}
};
class C:public B
{
public:
C()
{
cout<<"C"<<endl;
}
void print()
{
cout<<"C print"<<endl;
}
virtual ~C()
{
cout<<"~C"<<endl;
}
};
void print(A &a)
{
a.print();
}
void print2(A *pa)
{
pa->print();
}
void print3(A a)
{
a.print();
}
int main()
{
A a;
B b;
C c;
A *pa = new A;
delete pa;
c.i = 3;
a = c;
cout<< a.i << endl;
cout<<"*******对象输出******"<<endl;
a.print();
b.print();
c.print();
cout<<"*******改为父类的引用输出******"<<endl;
print(a);
print(b);
print(c);
cout<<"*******改为父类的指针输出******"<<endl;
print2(&a);
print2(&b);
print2(&c);
cout<<"*******改为父类的拷贝输出******"<<endl;
print3(a);
print3(b);
print3(c);
return 0;
}
/*一、虚函数时,对象生成,有个虚表指针地址,在类的首地址上,这个地址记录对象对应的类的虚函数表地址,所以对象的指针改成其它类型,但是虚表指针的值没变,依然执行对象对应的类型的虚函数
A
A
B
A
B
C
A
~A
3
*******对象输出******
A print
B print
C print
*******改为父类的引用输出******
A print
B print
C print
*******改为父类的指针输出******
A print
B print
C print
*******改为父类的拷贝输出******
A print
~A
A print
~A
A print
~A
*/
/*二、非虚函数时
A
A
B
A
B
C
A
~A
3
*******对象输出******
A print
B print
C print
*******改为父类的引用输出******
A print
A print
A print
*******改为父类的指针输出******
A print
A print
A print
*******改为父类的拷贝输出******
A print
~A
A print
~A
A print
~A
*/
/*三、当对象带入函数发生拷贝时,虚函数表指针地址的值不拷贝,只拷贝变量的值;不会执行构造函数,但会执行析构函数*/
/*四、对象赐值时,只对变量赐值,不会复制虚函数表指针地址的值*/