QT c++ 双精度浮点数转换成4个16位数

发布时间:2024年01月09日

在进行modbus通讯中,将双精度数写入设备中,需要把它拆成4个寄存器,再发出去。

在从设备中读取很多个寄存器时,其中可能包含双精度数,那么需要4个寄存器合成双精度数。

之前的文章中介绍了labview的方法。

那么在c++中如何办呢,用联合体union是一种方法

本文在QT中调试经验证正确。

将下面的函数拷贝如你自己的项目cpp文件中,记得将函数添加头文件。

union DoubleSplit
{
? ? double doubleValue; // 64位无符号整数
? ? struct {
? ? ? ? short? Word0;
? ? ? ? short? Word1;
? ? ? ? short? Word2;
? ? ? ? short? Word3;
? ? } sDoubleValues; ? ? ? // 结构体,包含4个16位有符号整数
? ? short ShortArray[4];
};

void func1()//写入时转换

{

????????double input = 10.111; // 输入要拆分的双精度浮点数

?????????DoubleSplit splitData;
? ? ? ? ?splitData.doubleValue = *(double*)&input;

? ? ? ? ?QVector<quint16> array;//定义写入的数组

? ? ? ? ?int n=0;//姑且认为在数组的开始4个元素定义的双精度数,实际情况修改偏移

? ? ? ? ?array[n+0]=splitData.ShortArray[0];
? ? ? ? ?array[n+1]=splitData.ShortArray[1];
? ? ? ? ?array[n+2]=splitData.ShortArray[2];
? ? ? ? ?array[n+3]=splitData.ShortArray[3];

}

func2()//读取时转换
{
? ? DoubleSplit splitData;
? ? QVector<quint16> array;//定义已经读到的数组
? ? array<<46662;
? ? array<<65011;
? ? array<<14548;

? ? array<<16420;

? ? int n=0;//姑且认为在数组的开始4个元素定义的双精度数,实际情况修改偏移

? ? splitData.ShortArray[0]=array[n+0];

? ? splitData.ShortArray[1]=array[n+1];

? ? splitData.ShortArray[2]=array[n+2];

? ? splitData.ShortArray[3]=array[n+3];
? ? double output= splitData.doubleValue;
? ? qDebug()<<output;//应该输出10.111
}

文章来源:https://blog.csdn.net/weixin_39926429/article/details/135486254
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。