最近工作需要用到float型的数据和二进制之间的转换,网上提到了一些方法,比较多的就是先分析float型数据在内存中的存放方式,然后根据IEEE标准进行转换。
个人觉得还是有点麻烦,看到其中有一种方法,感觉很精妙,记录下来,方便以后查看。总的思想就是获取每个字节的值,存放在uchar类型中,然后再转二进制就非常简单了。
首先我们来看一下,将float型数据转换为二进制。从下面的获取每个字节的值过程中,我们也可以看出,指针指向的是低位字节的首地址。
void main()
{
float fValue;
uchar ucArray[4];
uchar *pUch;
pUch=(uchar *)&fValue;
fValue=3.5;
//获取每个字符的值
for (int i=0;i<4;i++)
{
ucArray[i]=pUch[i];
}
//按照从高位到低位输出二进制
for (i=0;i<4;i++)
{
for (int j=0;j<8;j++)
{
if ((ucArray[3-i]<<j)&0x80)
{
printf("1");
}
else
{
printf("0");
}
}
printf(" ");
}
}
下面我们看怎么把二进制转换为float型的数据,原理一样,倒过来就行了。
//将二进制转换为float型
ucArray[0]=0x2d;
ucArray[1]=0xb2;
ucArray[2]=0xb5;
ucArray[3]=0x40;
for (i=0;i<4;i++)
{
pUch[i]=ucArray[i];
}
printf("\n%f\n",fValue);
其他的类型的数据也是同样的方法。