QT c++ 双精度浮点数转换成4个16位数
在进行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
 }
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!