天天看點

浮點型與16進制資料的互相轉換(C語言代碼)浮點型與16進制資料的互相轉換(C語言代碼)

浮點型與16進制資料的互相轉換(C語言代碼)

1.浮點型資料轉換16進制資料的原理

(1)正向流程:

以四個位元組的資料為準:4*8=32位 31位為符号,30到23八個位元組為階碼,由第二步計算得來,尾數部分則是剩餘的小數部分(由後23位決定)

1.将經緯度資料(10進制,浮點型)轉換成二進制形式;

2.小數點向左移動n位,直到最後一個1停止,得到左移的位數,計算階碼,127+(左移位數);

3.尾數(22到0位置總計23個位數)為小數部分的二進制編碼,剩餘未填滿的位數用0補齊;

4.再将所有得到的2進制編碼,轉換成16進制的資料。

(2)舉例:将十進制178.125表示成機器内的32個位元組的二進制形式。

第一步:将178.125表示成二進制數:(178.125)(十進制數)=(10110010.001)(二進制形式);

第二步:将二進制形式的浮點數轉化為規格化的形式:(小數點向左移動7個二進制位可以得到

10110010.001=1.0110010001*2^7 因而産生了以下三項:

符号位:該數為正數,故第31位為0,占一個二進制位;

階碼:指數為7,故其階碼為127+(7)=134=10000110,占從第30到第23共8個二進制位;

尾數為小數點後的部分, 即0110010001.因為尾數共23個二進制位,在後面補13個0,即01100100010000000000000

是以,178.125在記憶體中的實際表示方式為:

0 10000110 01100100010000000000000

經度轉換:

120.337402 将浮點型資料轉換成2進制數字

2.C語言代碼親測有效

#include <stdio.h>

float Hex_To_Decimal(unsigned char *Byte,int num)//十六進制到浮點數
{
//  	char cByte[4];//方法一
//     for (int i=0;i<num;i++)
//     {
// 	cByte[i] = Byte[i];
//     }
//      
// 	float pfValue=*(float*)&cByte;
//return  pfValue;
	
		return *((float*)Byte);//方法二



}

long FloatTohex(float HEX)//浮點數到十六進制轉換1
{
	return *( long *)&HEX;
}




void FloatToByte(float floatNum,unsigned char* byteArry)浮點數到十六進制轉換2
{
    char* pchar=(char*)&floatNum;
    for(int i=0;i<sizeof(float);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;
//     int num=sizeof(hexbyte);
// 	printf("num= %d\n",num);

    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=%x %x %x %x\n",Hdecimal,floatToHex[0],floatToHex[1],floatToHex[2],floatToHex[3] );//倒序顯示
	
	FloatToByte(flh,floatToHex);//浮點數轉為十六進制二

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

	FloatToByte(flh,floatToHex);//浮點數轉為十六進制二
	
    printf("\n正序十六進制:\n%f=%x %x %x %x\n",flh,floatToHex[3],floatToHex[2],floatToHex[1],floatToHex[0] );//高位在前
	 
	 
}
           

繼續閱讀