关于类型强制转换的问题

lxb316 2010-03-04 11:14:49


char buf[2] = {0xd2,0xfa};
float f = *((short *)buf);



最终的结果 f = -1326.0000
1、是如何计算的?

2、如何反计算? 就是如果已知f的值,反过来求buf?
...全文
115 11 打赏 收藏 转发到动态 举报
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
lxb316 2010-03-05
  • 打赏
  • 举报
回复
谢谢各位大侠,谢谢yuzl32、 stardust20(东东)、dubiousway
lxb316 2010-03-05
  • 打赏
  • 举报
回复
结贴给分,谢谢yuzl32
Fanwei_hit 2010-03-05
  • 打赏
  • 举报
回复
学习................
stardust20 2010-03-04
  • 打赏
  • 举报
回复
char buf[2] = {0xd2,0xfa};//从高到底就是0xfad2
float f = *((short *)buf);//以(short)的方式对内存中的0xfad2进行取值,转化为二进制也就是
1111101011010010。。负数在内存中以补码的形式存放。。所以要取反再加1...也就是-0000010100101110。。然后就等于-1326
然后再把这个数赋值给f
-1326.0000
huichengongzi 2010-03-04
  • 打赏
  • 举报
回复
学习学习学习学习学习学习中……
tianmo2010 2010-03-04
  • 打赏
  • 举报
回复
是,顶!~~
哈哈哈
dubiousway 2010-03-04
  • 打赏
  • 举报
回复
一个大数,一般在内存中存储的时候,就是数的低位(低字节)放在低地址的内存;数的高字节放高地址内存

比如 数(16进制) 是:0x12345678 (4 byte)
78 是低位,所以存放在地址最低的内存;
12是高位,放高地址

对数组来说 char buf[1024], buf[0] 。。。。buf[1023] 地址依次增高
yuzl32 2010-03-04
  • 打赏
  • 举报
回复
2、如何反计算? 就是如果已知f的值,反过来求buf?
--------
short s = (short)f;
buf[0] = ((char *)(&s))[0];
buf[1] = ((char *)(&s))[1];
机智的呆呆 2010-03-04
  • 打赏
  • 举报
回复
如何反计算? 就是如果已知f的值,反过来求buf?
反计算的话,lz得弄清楚float的存储方式
float和double变量的内存布局~~~~~~
http://blog.csdn.net/Demon__Hunter/archive/2008/12/20/3566232.aspx
huichengongzi 2010-03-04
  • 打赏
  • 举报
回复
顶!顶!顶了再看
哈呵呵。哈哈哈
yuzl32 2010-03-04
  • 打赏
  • 举报
回复
char buf[2] = {0xd2,0xfa};//从高到底就是0xfad2,也就是-1326.00

69,381

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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