C++ 使用libmodbus通信示例

2024-03-07 12:44

本文主要是介绍C++ 使用libmodbus通信示例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

代码示例

#include <future>
#include <iostream>
#include <thread>#include <modbus.h>// 寄存器数量
#define TEST_MAX_REGISTERS 100
// 读取寄存器数量
#define TEST_MAX_READ 5int main()
{// C++ 异步auto&& f1 = std::async(std::launch::async, []() {std::this_thread::sleep_for(std::chrono::seconds(1));uint16_t tab_reg[TEST_MAX_REGISTERS] = { 0 };// 创建Modbus上下文modbus_t* ctx = modbus_new_rtu("COM2", 9600, 'N', 8, 1);modbus_set_slave(ctx, 1);modbus_rtu_set_serial_mode(ctx, MODBUS_RTU_RS232);modbus_rtu_set_rts(ctx, MODBUS_RTU_RTS_UP);if (modbus_connect(ctx) == -1) {fprintf(stderr, "Connection failed: %s\n", modbus_strerror(errno));modbus_free(ctx);return;}modbus_set_response_timeout(ctx, 0, 1000000);while (true) {// 读取保持寄存器的值int rc = modbus_read_registers(ctx, 0, TEST_MAX_READ, tab_reg);if (rc == -1) {fprintf(stderr, "%s\n", modbus_strerror(errno));continue;}for (int i = 0; i < TEST_MAX_READ; ++i) {printf("<%#x>", tab_reg[i]);}printf("\n");std::this_thread::sleep_for(std::chrono::seconds(1));}});auto&& f2 = std::async(std::launch::async, []() {modbus_t* ctx = modbus_new_rtu("COM3", 9600, 'N', 8, 1);modbus_set_slave(ctx, 1);modbus_rtu_set_serial_mode(ctx, MODBUS_RTU_RS232);modbus_rtu_set_rts(ctx, MODBUS_RTU_RTS_UP);if (modbus_connect(ctx) == -1) {fprintf(stderr, "Connection failed: %s\n", modbus_strerror(errno));modbus_free(ctx);return;}// 创建寄存器映射modbus_mapping_t* mb_mapping = modbus_mapping_new(MODBUS_MAX_READ_BITS, 0, MODBUS_MAX_READ_REGISTERS, 0);if (mb_mapping == NULL) {fprintf(stderr, "Failed to allocate the mapping: %s\n", modbus_strerror(errno));modbus_free(ctx);return;}uint8_t query[MODBUS_TCP_MAX_ADU_LENGTH];while (true) {// 初始化寄存器for (size_t i = 0; i < TEST_MAX_REGISTERS; i++) {mb_mapping->tab_registers[i] = rand() % 100;}memset(query, 0, sizeof(query));// 读取寄存器值int rc = modbus_receive(ctx, query);if (rc == -1) {continue;}// 响应请求modbus_reply(ctx, query, rc, mb_mapping);}});while (true) {std::this_thread::sleep_for(std::chrono::seconds(1));}return 0;
}

效果

在这里插入图片描述

这篇关于C++ 使用libmodbus通信示例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/783559

相关文章

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

C#下Newtonsoft.Json的具体使用

《C#下Newtonsoft.Json的具体使用》Newtonsoft.Json是一个非常流行的C#JSON序列化和反序列化库,它可以方便地将C#对象转换为JSON格式,或者将JSON数据解析为C#对... 目录安装 Newtonsoft.json基本用法1. 序列化 C# 对象为 JSON2. 反序列化

QT Creator配置Kit的实现示例

《QTCreator配置Kit的实现示例》本文主要介绍了使用Qt5.12.12与VS2022时,因MSVC编译器版本不匹配及WindowsSDK缺失导致配置错误的问题解决,感兴趣的可以了解一下... 目录0、背景:qt5.12.12+vs2022一、症状:二、原因:(可以跳过,直奔后面的解决方法)三、解决方

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

Python中Json和其他类型相互转换的实现示例

《Python中Json和其他类型相互转换的实现示例》本文介绍了在Python中使用json模块实现json数据与dict、object之间的高效转换,包括loads(),load(),dumps()... 项目中经常会用到json格式转为object对象、dict字典格式等。在此做个记录,方便后续用到该方

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

SpringBoot请求参数传递与接收示例详解

《SpringBoot请求参数传递与接收示例详解》本文给大家介绍SpringBoot请求参数传递与接收示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录I. 基础参数传递i.查询参数(Query Parameters)ii.路径参数(Path Va

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

Python ORM神器之SQLAlchemy基本使用完全指南

《PythonORM神器之SQLAlchemy基本使用完全指南》SQLAlchemy是Python主流ORM框架,通过对象化方式简化数据库操作,支持多数据库,提供引擎、会话、模型等核心组件,实现事务... 目录一、什么是SQLAlchemy?二、安装SQLAlchemy三、核心概念1. Engine(引擎)