单精度浮点数与十六进制转换
#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] );//高位在前
}
评论