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)指针法

具体代码如下:

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];
}

测试用例如下:

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)共用体法

具体代码如下:

union {
 		float 	fdata;
 		unsigned char 	data[4];
}temp;

测试用例如下:

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()函数法

具体代码如下:

void Float_HEX (float fdata, unsigned char *hdata)
{
	memcpy(hdata,&fdata,sizeof(fdata));
}

测试用例如下:

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)指针法

具体代码如下:

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];
}

测试用例如下:

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)共用体法

具体代码如下:

union {
 		double 	 Ddata;
 		unsigned char 	data[8];
}temp;

测试用例如下:

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()函数法

具体代码如下:

void Double_HEX (double Ddata, unsigned char *hdata)
{
	memcpy(hdata,&Ddata,sizeof(Ddata));
}

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)

具体代码如下:

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)

具体代码如下:

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;
}

运行结果如下:
在这里插入图片描述

五、浮点二进制转换工具

参看:浮点二进制转换工具
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/224682.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

完数的C语言实现xdoj30

时间限制: 2 S 内存限制: 10000 Kb 问题描述: 请写一个程序&#xff0c;给出指定整数范围[a&#xff0c;b]内的所有完数&#xff0c;0 < a < b < 10000。 一个数如果恰好等于除它本身外的所有因子之和&#xff0c;这个数就称为"完数"。 例如6是…

git 关于分支、merge、commit提交

最近开始用git终端提交代码&#xff0c;梳理了一些知识点 一 关于分支 关于分支&#xff0c;git的分支分为本地分支远程分支两种分支&#xff0c;在上传代码时&#xff0c;我们要确保当前本地分支连接了一个远程分支。 我们可以通过下面代码查看当前的本地分支&#xff1a; g…

mybatis的分页插件

在mybatis核心配置文件中&#xff1a; 这时已经用了SSM整合&#xff0c;好多像是mapper或者数据源等都移出去了 <?xml version"1.0" encoding"UTF-8" ?> <!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""…

nodejs微信小程序+python+PHP新闻发布系统的设计与实现-计算机毕业设计推荐

目 录 摘 要 I ABSTRACT II 目 录 II 第1章 绪论 1 1.1背景及意义 1 1.2 国内外研究概况 1 1.3 研究的内容 1 第2章 相关技术 3 2.1 nodejs简介 4 2.2 express框架介绍 6 2.4 MySQL数据库 4 第3章 系统分析 5 3.1 需求分析 5 3.2 系统可行性分析 5 3.2.1技术可行性&#xff1a;…

这些Java并发容器,你都了解吗?

文章目录 前言并发容器1.ConcurrentHashMap 并发版 HashMap示例 2.CopyOnWriteArrayList 并发版 ArrayList示例 3.CopyOnWriteArraySet 并发 Set示例 4.ConcurrentLinkedQueue 并发队列 (基于链表)示例 5.ConcurrentLinkedDeque 并发队列 (基于双向链表)示例 6.ConcurrentSkipL…

【LLM_05】使用fastgpt搭建本地离线大语言模型(Chatglm3)问答+知识库平台

1、FastGPT 的知识库逻辑1.1 基础概念1.2 FastGPT知识库的导入1.3 FastGPT新建应用&#xff08;1&#xff09;创建一个知识库助手&#xff08;2&#xff09;创建一个python开发小助手 2、词向量比较测试2.1 开启词向量模型2.2 词向量模型性能比较 3、配置好之后的运行3.1 运行大…

Redis ziplist源码解析

area |<---- ziplist header ---->|<----------- entries ------------->|<-end->|size 4 bytes 4 bytes 2 bytes ? ? ? ? 1 byte--------------------------------------------------------------- comp…

多人聊天UDP

服务端 package 多人聊天;import java.io.BufferedReader; import java.io.InputStream; import java.io.InputStreamReader; import java.io.OutputStream; import java.io.PrintStream; import java.net.ServerSocket; import java.net.Socket; import java.util.ArrayList;…

第十六届山东省职业院校技能大赛中职组网络安全赛项竞赛正式试题

第十六届山东省职业院校技能大赛中职组网络安全"赛项竞赛试题 一、竞赛时间 总计&#xff1a;360分钟 二、竞赛阶段 竞赛阶段任务阶段竞赛任务竞赛时间分值A、B模块A-1登录安全加固180分钟200分A-2本地安全策略设置A-3流量完整性保护A-4事件监控A-5服务加固A-6防火墙策…

Error: Could not create the Java Virtual Machine(Linux启动tomcat成功后找不到进程8080端口)

文章目录 问题解决问题过程Tomcat版本要求 问题解决 版本冲突&#xff0c;我的jdk是1.8.x&#xff0c; tomcat 是 10.1.x的&#xff0c;要求jdk是11。 问题过程 运行 ./startup.sh 显示如下&#xff1a; 还以为运行成功呢&#xff0c; 使用命令一查&#xff0c;根本查不到进…

C语言进阶之路之内存镜像与字符操作函数篇

目录 一、学习目标&#xff1a; 二、内存镜像 什么是进程 C进程内存布局 栈内存 静态数据 数据段&#xff08;存储静态数据&#xff09;与代码段 堆内存 三、字符操作函数 函数strstr 函数strlen strlen与sizeof的区别 函数strtok 函数strcat与strncat 函数strc…

记录 | python向上取整和向下取整

python 向上取整和向下取整 向上取整 使用 ceil()&#xff1a; import mathx 0.55 x0 math.ceil(x)向下取整 使用 floor()&#xff1a; import mathx 0.55 x1 math.floor(x)如下&#xff1a;

群聊Java

服务端 import java.io.*; import java.net.*; import java.util.ArrayList; public class Server{public static ServerSocket server_socket;public static ArrayList<Socket> socketListnew ArrayList<Socket>(); public static void main(String []args){try{…

VR远程带看,助力线下门店线上化转型“自救”

VR远程带看&#xff0c;因自身高效的沉浸式在线沟通功能&#xff0c;逐渐走进了大众的视野。身临其境的线上漫游体验以及实时同屏互联的新型交互模式&#xff0c;提升了商家同用户之间的沟通效率&#xff0c;进一步实现了远程线上一对一、一对多的同屏带看&#xff0c;用户足不…

封装校验-----Vue3+ts项目

登录校验页面 <script setup lang"ts"> import { ref } from vue import { mobileRules, passwordRules } from /utils/rules const mobile ref() const password ref() </script><!-- 表单 --><van-form autocomplete"off">&l…

使用Draw.io制作泳道图

使用Draw.io制作泳道图 一、横向泳道图1. 有标题泳道图2. 无标题泳道图3. 横纵向扩展泳道 二、纵向泳道图三、横纵交错地泳道图想做这样的图具体步骤1. 拖拽一个带标题的横向泳道图2. 拖拽一个带标题的单一图&#xff0c;并且把它放进Lane1中3. 其他注意 四、下载文件说明 一、…

CSS的逻辑组合伪类

CSS 的逻辑组合伪类有 4 种&#xff0c;分别是&#xff1a;:not()、:is()、:where()和&#xff1a;has()。 否定伪类:not() :not 伪类选择器用来匹配不符合一组选择器的元素。由于它的作用是防止特定的元素被选中&#xff0c;它也被称为反选伪类&#xff08;negation pseudo-…

走迷宫(详细分析)

目录 一、课题描述 输入样例&#xff1a; 输出样例&#xff1a; 二、需求分析 输入的形式和输入值的范围&#xff1a; 输出的形式&#xff1a; 程序所能达到的功能&#xff1a; 三、概要设计 四、流程图 五 、代码详细注释 六、测试数据和结果 一、课题描述 以一个…

2024年江苏省职业院校技能大赛信息安全管理与评估 第三阶段学生组(样卷)

2024年江苏省职业院校技能大赛信息安全管理与评估 第三阶段学生组&#xff08;样卷&#xff09; 竞赛项目赛题 本文件为信息安全管理与评估项目竞赛-第三阶段样题&#xff0c;内容包括&#xff1a;网络安全渗透、理论技能与职业素养。 本次比赛时间为180分钟。 介绍 GeekSe…

上海亚商投顾:沪指窄幅震荡 多只高位股午后跳水

上海亚商投顾前言&#xff1a;无惧大盘涨跌&#xff0c;解密龙虎榜资金&#xff0c;跟踪一线游资和机构资金动向&#xff0c;识别短期热点和强势个股。 一.市场情绪 沪指昨日窄幅震荡&#xff0c;创业板指冲高回落。锂电池板块集体反弹&#xff0c;西藏矿业、吉翔股份、永兴材…
最新文章