C语言二进制和float、int类型转换

来源:互联网 发布:网络写作怎么赚钱 编辑:程序博客网 时间:2024/04/30 13:13
 最近工作需要用到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型的数据,原理一样,倒过来就行了。

    //将二进制转换为floatucArray[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);

其他的类型的数据也是同样的方法。

0 0