char buf[2] = {0xd2,0xfa};
float f = *((short *)buf);
最终的结果 f = -1326.0000
1、是如何计算的?
2、如何反计算? 就是如果已知f的值,反过来求buf?
一:
char buf[2] = {0xd2,0xfa};//从高到底就是0xfad2,也就是-1326.002、
如何反计算? 就是如果已知f的值,反过来求buf,
short s = (short)f;
buf[0] = ((char *)(&s))[0];
buf[1] = ((char *)(&s))[1];
二:
一个大数,一般在内存中存储的时候,就是数的低位(低字节)放在低地址的内存;数的高字节放高地址
内存
比如 数(16进制) 是:0x12345678 (4 byte)
78 是低位,所以存放在地址最低的内存;
12是高位,放高地址
对数组来说 char buf[1024], buf[0] 。。。。buf[1023] 地址依次增高
char buf[2] = {0xd2,0xfa};//从高到底就是0xfad2
float f = *((short *)buf);//以(short)的方式对内存中的0xfad2进行取值,转化为二进制也就是
1111101011010010。。负数在内存中以补码的形式存放。。所以要取反再加1...也就是-
0000010100101110。。然后就等于-1326
然后再把这个数赋值给f
-1326.0000
float f = *((short *)buf);
最终的结果 f = -1326.0000
1、是如何计算的?
2、如何反计算? 就是如果已知f的值,反过来求buf?
一:
char buf[2] = {0xd2,0xfa};//从高到底就是0xfad2,也就是-1326.002、
如何反计算? 就是如果已知f的值,反过来求buf,
short s = (short)f;
buf[0] = ((char *)(&s))[0];
buf[1] = ((char *)(&s))[1];
二:
一个大数,一般在内存中存储的时候,就是数的低位(低字节)放在低地址的内存;数的高字节放高地址
内存
比如 数(16进制) 是:0x12345678 (4 byte)
78 是低位,所以存放在地址最低的内存;
12是高位,放高地址
对数组来说 char buf[1024], buf[0] 。。。。buf[1023] 地址依次增高
char buf[2] = {0xd2,0xfa};//从高到底就是0xfad2
float f = *((short *)buf);//以(short)的方式对内存中的0xfad2进行取值,转化为二进制也就是
1111101011010010。。负数在内存中以补码的形式存放。。所以要取反再加1...也就是-
0000010100101110。。然后就等于-1326
然后再把这个数赋值给f
-1326.0000