1. 派生类对象可以强制转换为基类对象
#include <iostream>
using namespace std;
class base{
public:
int a;
base(int x=0):a(x){}
void print(){cout<<a<<endl;}
};
class son:public base
{
public:
char y;
son(char x):y(x){}
operator double(){ return 1.3423;}
void print(){cout<<y<<endl;}
};
int main()
{
son v('-');
((base)v).print();
cout<< (double)v <<endl;
cin.get();
return 0;
}强制转换类型可以自己定义如operator double()可以自定义类型转换。
son v('-');
0041140E push 2Dh // 临时变量
00411410 lea ecx,[v] // 取偏移地址
00411413 call son::son (4110EBh) // 利用目标地址调用son::son构造函数
base b(1);
00411418 push 1 // 临时变量
0041141A lea ecx,[b] // 曲偏移地址
0041141D call base::base (411104h) // 利用目标地址调用base::base构造函数
b.print();
00411422 lea ecx,[b] // 取b的偏移地址
00411425 call base::print (4110FFh) // 利用目标地址调用base::print输出函数
((base)v).print();
0041142A mov eax,dword ptr [v] // 将v指向的内容传递到eax
0041142D mov dword ptr [ebp-0E4h],eax // 将exa的内容放到一个新的内存空间,不是自由存储区
00411433 lea ecx,[ebp-0E4h] // 取存储空间偏移地址
00411439 call base::print (4110FFh) // 调用print函数,默认新内存空间是base对象
(double)v;
0041143E lea ecx,[v]
00411441 call son::operator double (411140h) // 调用类型转换函数进行转换
00411446 fstp st(0)默认派生类到基类的强制类型转换是内存的直接读取(有人认为调用了派生类的构造函数,构造了临时基类对象,要是这么理解也只能说调用了一部分构造函数,还是用内存拷贝的说法更直接到位)。
原文:http://blog.csdn.net/zcliatb/article/details/41720607