C语言再学习 -- 单精度(float)和双精度(double)浮点数 与 十六进制(HEX) 之间转换(转载))

之前讲过浮点数部分,参看:C语言再学习 -- 浮点数

现在程序中要将浮点数,通过TCP发送。那得先将其转换为十六进制才行呀。

那么问题就来了。

参看:C语言:单精度(float)和双精度(double)浮点数 与 十六进制(HEX) 之间转换

扩展:
STM32开发 -- 进制与字符串间的转换

一、浮点数 介绍

  • 单精度浮点float:可以精确到小数点后6位
  • 双精度浮点double:可以精确到小数点后12位

C可以通过f或F后缀是编译器把浮点常量当做float类型,比如2.3f和9.11E9F。

l或L后缀使一个数字成为long double类型,比如54.3l和4.32e4L。

建议使用L后缀,因为字母l和数字1容易混淆

没有后缀的浮点常量为double类型。(重点)。例:sizeof(1.9) = 8;

浮点数二进制表达的三个组成部分

Sign(1bit):表示浮点数是正数还是负数。 0表示正数,1表示负数
Exponent(8bits):指数部分。 类似于科学技术法中的M*10^N中的N,只不过这里是以2为底数而不是10。需要注意的是,这部分中是以2 ^ 7-1即127,也即01111111代表2 ^ 0,转换时需要根据127作偏移调整。
Mantissa(23bits):基数部分。 浮点数具体数值的实际表示。

单精度(float)浮点数----32位

具体结构如下表所示:

双精度(double)浮点数----64位

二、浮点数十六进制转换器

链接:浮点数十六进制转换器v1.1

提取码:775u

浮点数 13.88 单精度(float) 转 十六进制(HEX)为 41 5E 14 7B 双精度(double)转 十六进制(HEX)为

40 2B C2 8F 5C 28 F5 C3

三、C语言实现 浮点数 转 十六进制(HEX)

1、单精度(float) 转 十六进制(HEX)

(1)指针法

具体代码如下:

c 复制代码
void Float_HEX (float fdata, unsigned char *hdata)
{
	unsigned char* tdata = (unsigned char*)(&fdata);
	hdata[0] = tdata[0];
	hdata[1] = tdata[1];
	hdata[2] = tdata[2];
	hdata[3] = tdata[3];
}

测试用例如下:

c 复制代码
int main(int argc, char *argv[])
{
	unsigned char data[4] = {0,0,0,0};
	float fdata = 13.88;
	
	Float_HEX(fdata,data);

	for(int i=0;i<4;i++)
	printf("0x%X\n",data[i]);
	
	return 0;
}

由于我的电脑系统是小端模式,所以低字节在前。

运行结果如下:

(2)共用体法

具体代码如下:

c 复制代码
union {
 		float 	fdata;
 		unsigned char 	data[4];
}temp;

测试用例如下:

c 复制代码
int main(int argc, char *argv[])
{
	temp.fdata = 13.88;
	
	for(int i=0;i<4;i++)
	printf("0x%X\n",temp.data[i]);
	
	return 0;
}

由于我的电脑系统是小端模式,所以低字节在前。

运行结果如下:

(3)memcpy()函数法

具体代码如下:

c 复制代码
void Float_HEX (float fdata, unsigned char *hdata)
{
	memcpy(hdata,&fdata,sizeof(fdata));
}

测试用例如下:

c 复制代码
int main(int argc, char *argv[])
{
	unsigned char data[4] = {0,0,0,0};
	float fdata = 13.88;
	
	Float_HEX(fdata,data);
	
	for(int i=0;i<4;i++)
	printf("0x%X\n",data[i]);
	
	return 0;
}

由于我的电脑系统是小端模式,所以低字节在前。

运行结果如下:

2、双精度(double)转 十六进制(HEX)

(1)指针法

具体代码如下:

c 复制代码
void Double_HEX (double Ddata, unsigned char *hdata)
{
	unsigned char* tdata = (unsigned char*)(&Ddata);
	hdata[0] = tdata[0];
	hdata[1] = tdata[1];
	hdata[2] = tdata[2];
	hdata[3] = tdata[3];
	hdata[4] = tdata[4];
	hdata[5] = tdata[5];
	hdata[6] = tdata[6];
	hdata[7] = tdata[7];
}

测试用例如下:

c 复制代码
int main(int argc, char *argv[])
{
	unsigned char data[8] = {0,0,0,0,0,0,0,0};
	double Ddata = 13.88;
	
	Double_HEX(Ddata,data);

	for(int i=0;i<8;i++)
	printf("0x%X\n",data[i]);
	
	return 0;
}

由于我的电脑系统是小端模式,所以低字节在前。

运行结果如下:

(2)共用体法

具体代码如下:

c 复制代码
union {
 		double 	 Ddata;
 		unsigned char 	data[8];
}temp;

测试用例如下:

c 复制代码
int main(int argc, char *argv[])
{
	temp.Ddata = 13.88; 

	for(int i=0;i<8;i++)
	printf("0x%X\n",temp.data[i]);
	
	return 0;
}

由于我的电脑系统是小端模式,所以低字节在前。

运行结果如下:

(3)memcpy()函数法

具体代码如下:

c 复制代码
void Double_HEX (double Ddata, unsigned char *hdata)
{
	memcpy(hdata,&Ddata,sizeof(Ddata));
}
c 复制代码
int main(int argc, char *argv[])
{
	unsigned char data[8] = {0,0,0,0,0,0,0,0};
	double Ddata = 13.88;
	
	Double_HEX(Ddata,data);

	for(int i=0;i<8;i++)
	printf("0x%X\n",data[i]);
	
	return 0;
}

由于我的电脑系统是小端模式,所以低字节在前。

运行结果如下:

四、十六进制(HEX) 转 浮点数

1、十六进制(HEX) 转 单精度(float)

具体代码如下:

c 复制代码
int main(int argc, char *argv[])
{
	char data[4] = {0x7B,0x14,0x5E,0x41};
	float fdata = 0;
	
	memcpy(&fdata,data,sizeof(fdata));
	
	printf("fdata=%f\n",fdata);
	return 0;
}

运行结果如下:

2、十六进制(HEX) 转 双精度(double)

具体代码如下:

c 复制代码
int main(int argc, char* argv[])
{
	char data[8] = { 0xC3,0xF5,0x28,0x5C,0x8F,0xC2,0x2B,0x40 };
	double Ddata = 0;

	memcpy(&Ddata, data, sizeof(Ddata));

	printf("Ddata=%f\n", Ddata);
	return 0;
}

运行结果如下:

五、浮点二进制转换工具

参看:浮点二进制转换工具

相关推荐
Matlab程序猿小助手23 分钟前
【MATLAB源码-第303期】基于matlab的蒲公英优化算法(DO)机器人栅格路径规划,输出做短路径图和适应度曲线.
开发语言·算法·matlab·机器人·kmeans
不爱编程的小九九23 分钟前
小九源码-springboot097-java付费自习室管理系统
java·开发语言·spring boot
立志成为大牛的小牛29 分钟前
数据结构——二十九、图的广度优先遍历(BFS)(王道408)
数据结构·数据库·学习·程序人生·考研·算法·宽度优先
云知谷35 分钟前
【经典书籍】C++ Primer 第16章模板与泛型编程精华讲解
c语言·开发语言·c++·软件工程·团队开发
屁股割了还要学42 分钟前
【Linux入门】常用工具:yum、vim
linux·运维·服务器·c语言·c++·学习·考研
workflower1 小时前
基本作业-管理⾃⼰的源代码
开发语言·单元测试·软件工程·需求分析·个人开发
froginwe111 小时前
Pandas DataFrame:深入理解数据分析的利器
开发语言
Jm_洋洋1 小时前
【Linux系统编程】程序替换:execve(execl、execlp、execle、execv、execvp、execvpe)
linux·运维·c语言·开发语言·程序人生
小莞尔1 小时前
【51单片机】【protues仿真】基于51单片机秒表计时器系统(带存储)
c语言·stm32·单片机·嵌入式硬件·物联网·51单片机
冯诺依曼的锦鲤2 小时前
算法练习:前缀和专题
开发语言·c++·算法