单精度浮点数与十六进制转换

嵌入式Linux

2020-09-29 17:48

#include 

/*---------------------------
十六进制到浮点数
---------------------------*/
float Hex_To_Decimal(unsigned char *Byte,int num)
{
#if 0
 char cByte[4];//方法一
 for (int i=0;i {
  cByte[i] = Byte[i];
 }
 
 float pfValue=*(float*)&cByte;
 return  pfValue;
#else 
 return *((float*)Byte);//方法二
#endif
}

long FloatTohex(float HEX)//浮点数到十六进制转换1
{
 return *( long *)&HEX;
}

void FloatToByte(float floatNum,unsigned char* byteArry)//浮点数到十六进制转换2
{
    char* pchar=(char*)&floatNum;
    int i = 0;
    for( i=0;ifloat);i++)
    {
  *byteArry=*pchar;
  pchar++;
  byteArry++;
 
    }
}


void main()
{

    unsigned char floatToHex[4];
    unsigned    char hexbyte[4]={0xcd,0xCC,0xCC,0x3D};//传输数据为3d cc cc cd
 float Hdecimal=0.0;
 float flh=0.4;


    Hdecimal=Hex_To_Decimal(hexbyte,sizeof(hexbyte));//十六进制转换为浮点数
 printf("\n 浮点数为:\n %f\n",Hdecimal);
 
 long hX=FloatTohex(Hdecimal);//浮点数转换为十六进制一

 printf("\n正序十六进制值:\n %f=%X \n",Hdecimal,hX);//正序显示

 FloatToByte(Hdecimal,floatToHex);//浮点数转为十六进制二
 
    printf("\n倒序十六进制:\n%f=%.2X %.2X %.2X %.2X\n",Hdecimal,floatToHex[0],floatToHex[1],floatToHex[2],floatToHex[3] );//倒序显示
 
 FloatToByte(flh,floatToHex);//浮点数转为十六进制二

    printf("\n倒序十六进制:\n%f=%.2X %.2X %.2X %.2X\n",flh,floatToHex[0],floatToHex[1],floatToHex[2],floatToHex[3] );//低位在前

 FloatToByte(flh,floatToHex);//浮点数转为十六进制二
 
    printf("\n正序十六进制:\n%f=%.2X %.2X %.2X %.2X\n",flh,floatToHex[3],floatToHex[2],floatToHex[1],floatToHex[0] );//高位在前
  
  
}





推荐阅读:
    专辑|Linux文章汇总
    专辑|程序人生
    专辑|C语言


嵌入式Linux
微信扫描二维码,关注我的公众号 
浏览 138
点赞
评论
收藏
分享

手机扫一扫分享

举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

举报