ros多线程下订阅、发布内部原理探究

这篇文章写的很详细
在这里插入图片描述
订阅内部流程如上,注意到:是消息加入Subscribe队列,回调函数加入Callback queue,多个AsyncSpinner相当于开了多条take线

首先:未使用ros::MultiThreadedSpinner和ros::AsyncSpinner的单线程、多线程执行回调函数时,就一个执行器顺序执行。
在这里插入图片描述一个队列长5,一个长3.调用一次spinonce(),一次执行所有消息队列中的回调函数(8个),且执行顺序abababaa,前3次分别顺序执行,a队列还多了2个后全部执行完毕。

所以,有数据丢失情况。回调函数A被调用并迅速执行完毕。
事件循环开始调用回调函数B,但由于B的执行时间较长,A事件循环被阻塞。
**

在B执行期间,A有新的消息到达,但由于事件循环被阻塞,这些消息无法及时处理,可能会被丢弃。 只有当B执行完毕后,事件循环才能继续执行下一个回调函数或处理其他事件。

**

2:当回调函数的执行时间超过了通过 r.sleep() 函数指定的延迟时间,回调函数将会持续不断地被执行 ,而无法按预期的延迟时间间隔执行。这是因为回调函数的执行时间超过了程序中设置的等待时间,导致在回调函数执行完之前就被再次触发
在这里插入图片描述
结果就是,像写了ros::spin()一样,一直在回调函数

ROS(Robot Operating System)是一个用于构建机器人应用程序的开源框架。它提供了一系列工具、库和约定,用于简化机器人软件开发的过程。ROS中,多线程发布订阅是一常见的通信机制,用于实现不同节点之间的数据传。 在ROS中,发布者(Publisher)节点责将数据发布到特定的主题(Topic),而订阅者(Subscriber)节点则负责从主题中接收数据。多线程发布订阅允许多订阅者同时接收来自同一个主题的数据,从而提高系统的并发性能。 在Python中使用ROS进行多线程发布订阅,可以按照以下步骤进行: 1. 导入所需的ROS库和模块: ```python import rospy from std_msgs.msg import String ``` 2. 初始化ROS节点: ```python rospy.init_node('node_name') ``` 3. 创建发布者对象,并指定要发布的主题和消息类型: ```python pub = rospy.Publisher('topic_name', String, queue_size=10) ``` 4. 创建订阅者回调函数,用于处理接收到的消息: ```python def callback(data): rospy.loginfo("Received: %s", data.data) ``` 5. 创建订阅者对象,并指定要订阅的主题和消息类型,以及回调函数: ```python sub = rospy.Subscriber('topic_name', String, callback) ``` 6. 编写发布数据的逻辑,并使用发布者对象发布消息: ```python rate = rospy.Rate(10) # 设置发布频率为10Hz while not rospy.is_shutdown(): msg = "Hello ROS!" pub.publish(msg) rate.sleep() ``` 以上是使用ROS进行多线程发布订阅的基本步骤。通过创建发布者和订阅者对象,并在回调函数中处理接收到的消息,可以实现节点之间的数据传输和通信。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值