c语言 union转换float char,union实现float和char的相互转换

本文介绍了如何使用union结构在C语言中实现float到uchar和uchar到float的双向转换,以解析Modbus通信中的十六进制浮点数数据。通过实例展示了如何将接收到的数据转换为有意义的参数值,便于后续分析和应用。
摘要由CSDN通过智能技术生成

今天利用了union实现float和char的相互转换,也就是说实现了一个float型数据转换成它对应的4个字节的uchar型,同时把4个字节的uchar型可以转换成由它们组成的float型。主要代码如下:

定义一个成员是uchar和float型的uniom:

union

{

float sub_float;

struct  {

uchar b1,b0,b3,b2;     //LSB

} sep_float ;

} u_float;

下面两个子函数可以是实现相互转换:

1、float转uchar

void Write_Xram_Float(uint addr,float write_data)

{

u_float.sub_float = write_data;

DatRead[addr+0] = u_float.sep_float.b3;

DatRead[addr+1] = u_float.sep_float.b4;

DatRead[addr+2] = u_float.sep_float.b1;

DatRead[addr+3] = u_float.sep_float.b2;

}

1、uchar转float

float Read_RAM_Float(uint addr)

{

u_float.sep_float_ram.b3 = DatRead(addr+0);

u_float.sep_float_ram.b2 = DatRead(addr+1);

u_float.sep_float_ram.b1 = DatRead(addr+2);

u_float.sep_float_ram.b0 = DatRead(addr+3);

return(u_float.sub_float);

}

我是用串口调试助手监听上位机的Modbus通信数据信息,分析监听到的数据,因为监听到的都是十六进制,所以,一个float由四个字节组成,起初根本不知道它代表的意义,通过上面的转换,我知道了它代表一个参数的值,完成监听工作;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值