在进行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
}