浮点数相关
来源:互联网 发布:大逃杀优化设置 编辑:程序博客网 时间:2024/03/29 13:13
原贴地址:http://software.intel.com/zh-cn/blogs/2010/09/09/c-5/?cid=sw:prccsdn1307
4、下面的程序会输出什么?
#include
int main()
{
float a = 12.5;
printf("%d/n", a);
printf("%d/n", (int)a);
printf("%d/n", *(int *)&a);
return 0;
}
参考答案:该项程序输出如下所示, 0 12 1095237632 原因是:浮点数是4个字节,12.5f 转成二进制是:01000001010010000000000000000000,十六进制是:0x41480000,十进制是:1095237632。所以,第二和第三个输出相信大家也知道是为什么了。而对于第一个,为什么会输出0,我们需要了解一下float和double的内存布局,如下:
float: 1位符号位(s)、8位指数(e),23位尾数(m,共32位)
double: 1位符号位(s)、11位指数(e),52位尾数(m,共64位)
然后,我们还需要了解一下printf由于类型不匹配,所以,会把float直接转成double,注意,12.5的float和double的内存二进制完全不一样。别忘了在x86芯片下使用是的反字节序,高位字节和低位字位要反过来。所以:
float版:0x41480000 (在内存中是:00 00 48 41)
double版:0x4029000000000000 (在内存中是:00 00 00 00 00 00 29 40)
而我们的%d要求是一个4字节的int,对于double的内存布局,我们可以看到前四个字节是00,所以输出自然是0了。 这个示例向我们说明printf并不是类型安全的,这就是为什么C++要引如cout的原因了。
- 浮点数相关
- 浮点数格式及相关实验
- 浮点数的相关运算Java实现
- 浮点数相关反汇编知识
- ACM浮点数相关的陷阱
- C++浮点数输出位数控制相关函数
- php中浮点数相关处理(待完善)
- 浮点数
- 浮点数
- 浮点数
- 浮点数
- 浮点数
- 浮点数
- 浮点数
- 浮点数
- 浮点数
- 浮点数
- 浮点数
- EXT2文件系统、虚拟文件系统、proc文件系统
- ADO Sample
- flex 客户端缓存 module swf
- 半年总结
- jsp注释应用
- 浮点数相关
- 高质量C++/C编程指南
- 如何退出android程序
- 感觉自己有点老了
- office2010带来gpu问题
- 附加数据库失败
- C++primer 关联容器
- 简单说说SSDT
- MySQL数据库中,如何记录SQL执行语句