


如上图所示,Publisher以Topic这个通道为媒介,发布各种message至Subscriber。
话题通信实际范例如下:

如上图所示,有一个话题Topic叫做/image_data,发布者publisher为CameraNode,通过这个话题发布各种message,然后两个订阅者subscriber分别为ImageProcessingNode和ImageDisplayNode,从话题中订阅到这个message。

Service Client向Service Server发送request请求数据,Service Server接收到之后,向Service Client发送response应答数据。

ImageProcessingNode向CameraNode发送request数据,CameraNode接收到之后执行对应指令,执行结束后发送reply应答至ImageProcessingNode,此时ImageProcessingNode知悉结果。
| 话题 | 服务 | |
|---|---|---|
| 同步性 | 异步 | 同步 |
| 通信模型 | 发布/订阅 | 服务器/客户端 |
| 底层协议 | ROSTCP/ROSUDP | ROSTCP/ROSUDP |
| 反馈机制 | 无(无应答) | 有(一来一回) |
| 缓冲区 | 有 | 无 |
| 实时性 | 弱 | 强 |
| 节点关系 | 多对多 | 一对多(一个server) |
| 适用场景 | 数据传输 | 逻辑处理 |
ROS Master维护的参数服务器,该参数服务器会来保存一部分参数作为全局共享字典,所有节点都可以通过网络访问这个共享字典

上图中,Talker和Listener都可以找ROS Master设置一个变量。例如Talker设置参数(setParam),参数名为’foo’,参数的值为1;那么Listener就可以去访问master来获取(getParam)参数’foo’;这个时候ROS Master就会提供参数foo的值为1。
