浮点数的储存~问题~

KID_coder 2010-09-09 07:44:21
#include <iostream>

using namespace std;

typedef union
{
float val;
unsigned num;
}test;

int main()
{
test T;
T.val = 1.23f;
for ( int i=0; i<32; ++i )
{
cout << ( ( (T.num) & 0x80000000 ) >> 31 ) << ends; //取最高位cout出来
T.num = (T.num) << 1; //num左移一位
}
cout << endl;
return 0;
}

刚学计算机组成原理,试在vc6上验证一下储存浮点数的问题~~但得不到想要的结果~
符号位 指数位 小数部分 指数偏移量
1 位[31] 8位 [30-23] 23位 [22-00] 127
~~到底是我的问题~还是我写程序的问题~
哪位高手指点下
...全文
59 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
ningweidong 2010-09-09
  • 打赏
  • 举报
回复
浮点数的存储很复杂的。可能VC6不是这样存的。
pengzhixi 2010-09-09
  • 打赏
  • 举报
回复
你先了解浮点数的存储方式吧
lazy_2010 2010-09-09
  • 打赏
  • 举报
回复
T.num = ( (T.num) << 1 );

试一试

64,691

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧