[文档下载] 如何把float类型的变量发送到串口调试助手,float在单片机中...

[复制链接]
3003|10
 楼主| Messi1999 发表于 2015-12-15 20:08 | 显示全部楼层 |阅读模式
有位小伙伴问,怎么把float类型的变量发送到串口调试助手?在这里给大家统一说一下。
什么时候用float类型的变量?
单片机计算数据,当用到小数的时候,我们一般就定义一个float类型的变量。
float类型占用几个字节?
我们知道,char占用1个字节,int占用2个字节。那么float类型的变量占用几个字节呢?答案是4个。
float类型变量存储遵循IEEE 754标准,关于IEEE754标准,你可以去百度,不过你看了也会头大,不一定能看懂。看懂看不懂,都不重要了。
那么,比如,3.141这个数在单片机中存储的4个字节分别是多少呢?
你可以借助一个软件(浮点数十六进制转换器)来看,
如下所示:
浮点数:30141
十六进制:单精度float:40490625



如果你不想用这个软件,可以把4个字节发送到串口调试助手来看。不过,float类型的变量是不能进行位移运算的。所以,假如你定义了一个x变量,当你写语句UART_Send(xxx>>24);UART_Send(xxx>>16);UART_Send(xxx>>8);UART_Send(xxx);的时候,编译器会报错。而当你用int把float强制转换后,就会只剩下整数部分,实际上,4个字节的内容已经改变。
 楼主| Messi1999 发表于 2015-12-15 20:08 | 显示全部楼层
正确方法:
用c语言关键字union来解决。
  1. union xxx
  2. {
  3. char c[4];
  4. float f;
  5. }y;

 楼主| Messi1999 发表于 2015-12-15 20:09 | 显示全部楼层
定义一个“共用体”xxx,y作为“共用体变量”,里面再定义一个char类型的变量数组c[4]和float类型的变量f。
根据union的定义,里面的变量占用同一个内存地址。所以,c[4]和f的内存地址是一样的,说的再通俗一点,就是c[4]的4个数实际上就是f的四个字节。
接着前面提出的问题。把3.141给了f,即f=3.141,那么,你就可以把c[4]数组的4个字节发送到串口调试助手了
  1. y.f=3.141;
  2. UART_Send(y.c[0]);
  3. UART_Send(y.c[1]);
  4. UART_Send(y.c[2]);
  5. UART_Send(y.c[3]);

评论

这样做发送的数据不对呀  发表于 2019-7-19 09:42
你这个代码还复杂了,用循环,代码就2行。 y.f=3.141; for(i=0;i<4;i++){UART_Send(y.c[i])};  发表于 2018-8-18 11:25

评分

参与人数 1威望 +3 收起 理由
tianxj01 + 3 赞一个!

查看全部评分

捉虫天师 发表于 2016-1-31 14:23 | 显示全部楼层
:handshake不错!
lovecat2015 发表于 2016-2-1 17:01 | 显示全部楼层
串口只能发送字符串吧
734774645 发表于 2016-2-2 13:35 | 显示全部楼层
3.141这个数在单片机中存储的4个字节分别是多少呢?
你可以借助一个软件(浮点数十六进制转换器)来看,
如下所示:
浮点数:30141
十六进制:单精度float:40490625
进击的生菜 发表于 2018-8-18 10:28 | 显示全部楼层
好像不是很好用  有人成功过吗  分享一下经验
tianxj01 发表于 2018-8-18 11:21 | 显示全部楼层
Messi1999 发表于 2015-12-15 20:09
定义一个“共用体”xxx,y作为“共用体变量”,里面再定义一个char类型的变量数组c[4]和float类型的变量f。 ...

正解,事实上,我们一般对于基本存储类型8位的 比如EEPROM,存储float变量,或者类似串口发送,用的都是这个,关键是代码短,效率高,完全不需要什么高低拆分、移位处理。
xixi2017 发表于 2019-7-19 11:28 | 显示全部楼层
接收端处理,发出来的应该都是字符串。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

36

主题

363

帖子

1

粉丝
快速回复 在线客服 返回列表 返回顶部