关于数据类型的一个小问题 (int) (int &) (int ) &
2010-10-23 17:55
513 查看
如下的一个程序他的输出是什么?
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
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
相关文章推荐
- 关于int类型数据在内存中的高低位存储问题
- 关于一个int *ptr=(int *)(&a+1)问题的探讨
- 关于一个int *ptr=(int *)(&a+1)问题的探讨
- 关于一个int *ptr=(int *)(&a+1)问题的探讨
- 关于一个int *ptr=(int *)(&a+1)问题的探讨
- 一个关于Java数据类型的有趣问题
- 关于MySQL的TinyInt数据类型在Delphi中作为Boolean类型的一个要注意的问题
- 一个有趣的 int 与 float 数据类型的小问题
- 定义一个不受计算机字长限制的整数类INT,要求INT与INT以及INT与C++基本数据类型int之间能进行+、-、×、÷和=运算,并且能通过cout输出INT类型的值。(持续添加)
- 关于一个int *ptr=(int *)(&a+1)问题的探讨
- 关于基本数据类型转换的一个小问题
- 有关java中数据类型byte,int的一个小问题
- 关于int类型的数据的几个问题
- 关于int类型数据在内存中的高低位存储问题
- 关于sql条件语句where id in (@参数)执行报错问题(转换成数据类型 int 时失败)(
- 关于数据类型与指针的小笔记--初始化问题&&数组
- 一个关于数据类型的问题
- 关于一个int *ptr=(int *)(&a+1)问题的探讨
- 关于一个int *ptr=(int *)(&a+1)问题的探讨
- 关于一个数据类型的溢出问题