C++ modbus 通信中Long与Float数据解析

 如图所示:

Long Inverse接收到的数据解析:

showData = array[0] << 16 | array[1];

Long 接收到的数据解析:

showData = array[1] << 16 | array[0];

Float Inverse接收到的数据解析:

float modbus_float_inverse(uint16_t value1, uint16_t value2)
{
    float temp;
    char *Modbus_HoldReg[4];
    Modbus_HoldReg[0] = ((char*)(&temp)) + 3;
    Modbus_HoldReg[1] = ((char*)(&temp)) + 2;
    Modbus_HoldReg[2] = ((char*)(&temp)) + 1;
    Modbus_HoldReg[3] = ((char*)(&temp)) + 0;
    *Modbus_HoldReg[0] = (value1 >> 8) & 0xff;
    *Modbus_HoldReg[1] = value1 & 0xff;
    *Modbus_HoldReg[2] = (value2 >> 8) & 0xff;
    *Modbus_HoldReg[3] = value2 & 0xff;

    return temp;
}

或者

float modbus_float_inverse(uint8_t value1, uint8_t value2, uint8_t value3, uint8_t value4)
{
	float temp;
	char *Modbus_HoldReg[4];
	Modbus_HoldReg[0] = ((char*)(&temp)) + 3;
	Modbus_HoldReg[1] = ((char*)(&temp)) + 2;
	Modbus_HoldReg[2] = ((char*)(&temp)) + 1;
	Modbus_HoldReg[3] = ((char*)(&temp)) + 0;
	*Modbus_HoldReg[0] = value1;
	*Modbus_HoldReg[1] = value2;
	*Modbus_HoldReg[2] = value3;
	*Modbus_HoldReg[3] = value4;

	return temp;
}

Float 接收到的数据解析:

float modbus_float(uint16_t value1, uint16_t value2)
{
    float temp;
    char *Modbus_HoldReg[4];
    Modbus_HoldReg[0] = ((char*)(&temp)) + 3;
    Modbus_HoldReg[1] = ((char*)(&temp)) + 2;
    Modbus_HoldReg[2] = ((char*)(&temp)) + 1;
    Modbus_HoldReg[3] = ((char*)(&temp)) + 0;
    *Modbus_HoldReg[0] = (value2 >> 8) & 0xff;
    *Modbus_HoldReg[1] = value2 & 0xff;
    *Modbus_HoldReg[2] = (value1 >> 8) & 0xff;
    *Modbus_HoldReg[3] = value1 & 0xff;

    return temp;
}

Float发送数据解析:

float data = 12.5;

uint16_t write_regs[2] = {0};   

memcpy(write_regs, &data, sizeof(float));

for(int i = 0 ; i < 2; i++) // ABCD模式
    printf("data change write_regs[%d] = 0x%02x\n",i,write_regs[i]);	

uint16_t t;
t = write_regs[0];
write_regs[0] = write_regs[1];
write_regs[1] = t;

for(int i = 0 ; i < 2; i++) // CDAB模式
    printf("data change write_regs[%d] = 0x%02x\n",i,write_regs[i]);	

你可以在GitHub上找到一个名为"modbuspp"的C++库,它是用于Modbus TCP客户端协议的库。你可以在这个链接上找到该库的详细信息和使用方法:\[1\]。 此外,你还可以在CSDN博客上找到有关C++ Modbus通信LongFloat数据解析的实例和教程。这篇博客文章提供了关于如何解析LongFloat数据的详细说明:\[2\]。 Modbus是一种串行通信协议,最初由Modicon于1979年发布,用于可编程逻辑控制器(PLC)的通信。它是工业领域通信协议的行业标准,并且在工业电子设备之间非常常用。Modbus协议在OSI7层模型位于数据链路层和物理层之间,使用的物理层可以是RS485/RS422/RS232等。Modbus帧格式也有一定的规范和格式要求。如果你需要更多关于Modbus协议的信息,你可以参考相关资料和文档。\[3\] #### 引用[.reference_title] - *1* *2* [【modbus.h使用】C++ Modbus Tcp实例-读写float](https://blog.csdn.net/cxyhjl/article/details/124750399)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [modbus rtu协议 认知篇](https://blog.csdn.net/qq_39854159/article/details/123330612)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值