当前位置: 首页 > news >正文

ROS2中的srv、action、发布订阅三种方式

ROS2中的srv、action、发布订阅三种方式

以下是ROS2中srv、action、发布订阅三种方式的差异和使用场景的表格形式呈现:

特性/方式srv(服务)action(动作)发布订阅(Publish-Subscribe)
通信模式请求-响应目标-反馈-结果异步消息传递
消息结构自定义请求和响应消息目标、反馈和结果消息单一消息类型
通信方向双向(客户端-服务端)双向(客户端-服务端),带反馈流单向(发布者-订阅者)
同步性同步(客户端等待服务端响应)异步,但客户端可跟踪状态异步
适用场景需要明确请求和响应的场景长时间运行的任务,需要反馈和可抢占连续数据流,无需立即响应
实例查询节点状态、数学运算机械臂运动控制、路径规划传感器数据发布、控制指令接收
使用方式定义.srv文件,创建服务端和客户端定义action接口,创建action server和action client定义消息类型,创建发布者和订阅者

差异说明

  • srv(服务):在ROS2中,服务是一种同步的通信机制,允许节点之间进行请求-响应模式的通信。服务类型定义了请求和响应的消息结构,可以使用.srv文件来定义自定义服务类型。服务通常用于需要明确请求和相应结果的应用场景,如查询节点状态或进行数学运算。
  • action(动作):动作是ROS2中用于处理长时间运行任务的通信类型。它们由目标、反馈和结果三部分组成,允许客户端在任务执行过程中接收反馈,并可以取消任务。动作建立在服务和发布订阅之上,提供了更丰富的交互模式。动作通常用于机械臂运动控制、路径规划等需要长时间运行和反馈的任务。
  • 发布订阅(Publish-Subscribe):发布订阅是ROS2中最基本的通信方式,允许节点之间异步地传递消息。发布者将消息发送到主题上,订阅者则从主题上接收消息。这种方式适用于连续数据流和无需立即响应的场景,如传感器数据发布和控制指令接收。

使用场景

  • srv:适用于那些需要明确请求和响应的场景,如查询一个节点的状态或进行数学运算。
  • action:适用于需要长时间运行的任务,如机械臂的运动控制或路径规划。动作提供了稳定的反馈流,允许客户端在任务执行过程中跟踪状态,并可以取消任务。
  • 发布订阅:适用于连续数据流和无需立即响应的场景。发布者将消息发送到主题上,订阅者从主题上接收消息,实现数据的异步传递。
http://www.lryc.cn/news/452190.html

相关文章:

  • HarmonyOS/OpenHarmony 自定义弹窗页面级层级控制解决方案
  • C/C++进阶(一)--内存管理
  • docker-compose 快速部署clickhouse集群
  • 闯关训练三:Git 基础知识
  • Java--IO基本流
  • 结合大语言模型的机械臂抓取操作简单介绍
  • Vivado - BD(差分时钟、简单分频、RESET、KEY)
  • 7--苍穹外卖-SpringBoot项目中套餐管理 详解(一)
  • 【尚硅谷】RocketMQ 消息队列学习笔记
  • C题(三)芝麻开门 --- strcmp函数应用
  • C++函数模板、选择排序实现(从大到小)
  • EasyExcel使用介绍
  • 字段临时缓存包装器
  • Python(三)——列表
  • MySQL--三大范式(超详解)
  • 追梦无Bug的软件世界
  • 在C#中使用Redis实现高效消息队列
  • 微服务JMeter解析部署使用全流程
  • Python 从入门到实战32(数据库MySQL)
  • hrnet训练的pt模型结合目标检测进行关键点识别的更准确前向推理
  • Leetcode 3306. Count of Substrings Containing Every Vowel and K Consonants II
  • 算法笔记(五)——分治
  • 多级侧边菜单(递归)
  • JavaScript break与continue语句
  • 算法【从递归入手一维动态规划】
  • Linux中的进程间通信之共享内存
  • 第18周 3-过滤器
  • Linux之进程概念
  • 小程序-使用npm包
  • 【springboot】整合沙箱支付