QTc++双精度浮点数转换成4个16位数
- 创业
- 2025-08-06 09:39:01

在进行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 }
QTc++双精度浮点数转换成4个16位数由讯客互联创业栏目发布,感谢您对讯客互联的认可,以及对我们原创作品以及文章的青睐,非常欢迎各位朋友分享到个人网站或者朋友圈,但转载请说明文章出处“QTc++双精度浮点数转换成4个16位数”