如下的一个程序他的输出是什么?
int main()
{
float a=1.0f;
cout<<(int) a<<endl;
cout<<(int &)a<<endl;
cout<<(int) &a<<endl;
return 0;
}
output:
1
1065353216
2488960
第一个输出我们可以知道会输出 1
第三个输出我们可以知道会输出 a的地址
第二个输出的是什么?
输出的是把浮点数a所占的四个字节直接转化成整形得到的数
我们使用以下的例子来尝试:
struct fourbit
{
unsigned char bit[4];
};
int main(int argc,char *argv)
{
float a=1.0f;
fourbit t;
memcpy(&t,&a,sizeof(float));
for (int i = 0; i < 4; i++) cout<<(int)t.bit[i]<<endl;
}
输出的结果是
0
0
128
63
分别转化为二进制 得到四个字节分别为 00000000 00000000 10000000 00111111
由于是小尾端 所以二进制数是 00111111 10000000 00000000 00000000
转化为十进制 就是1065353216