16进制转float类型数据

一、问题描述:
上位机发送0x44 发送一次数据
通讯格式:9600,8,1,N
通讯输出7字节(53 00 03 A9 84 0D 0A),格式如下:
1.字首(53)1字节
2.测量值(00 03 A9 84)4字节的16进制数 转10进制240004软件写为24.0004mm(定义公差名义值及4位小数)
3.结束符(0D 0A)2字节
如上所述,我们需要将测量值转换成Float类型
二、代码实现:
//子程序:
float u8Arry2float(char *data, bool key)
{
//false默认表示小端存储,注意大小端问题,因此设置1个布尔变量,可以随时切换
char uc[4];
if (key == true)
{
uc[3] = data[0];//将数据载入char数组中
uc[2] = data[1];
uc[1] = data[2];
uc[0] = data[3];
}
else
{
uc[0] = data[0];
uc[1] = data[1];
uc[2] = data[2];
uc[3] = data[3];
}
return ((uc[0]<< 24) + (uc[1] << 16) + (uc[2] << 8) + (uc[3] << 0));//硬码拼接
}
//主程序调用
pdata = u8Arry2float(ub, false);//注意pdata的数据类型也为float

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值