项目心得------发布者和订阅者问题解决思路
在发布者和订阅者项目中,当我运行订阅者的时候,发现订阅者espeak执行不了朗读的问题,我用了以下的步骤去解决问题。
一、检查订阅者代码是否有问题
我把每个关键的代码都进行输出,即在下一行添加,self.get_logger.info(f' ')来检测代码到哪运行不了。例如下图:
python
import rclpy
from rclpy.node import Node
from example_interfaces.msg import String #从example_interfaces包中导入String消息类型
import threading
from queue import Queue
import time
import espeakng
class NovelSubNode(Node):
def __init__(self, node_name):
super().__init__(node_name)
self.get_logger().info('小说朗读节点启动')
self.novels_queue_= Queue()
self.get_logger().info('正在创建小说订阅者...')
self.novel_subscriber_ = self.create_subscription(
String,'novel',self.novel_callback,10
)
self.get_logger().info('小说订阅者创建成功,正在等待小说内容...')
self.speech_thread_=threading.Thread(target=self.speak_thread)
self.get_logger().info('启动小说朗读线程...')
self.speech_thread_.start()
self.get_logger().info('小说朗读线程启动成功')
def novel_callback(self, msg):
# if msg.data=='':
# self.get_logger().info('收到空小说内容,忽略该消息')
# else:
self.novels_queue_.put(msg.data)
self.get_logger().info('收到小说内容,已加入朗读队列')
def speak_thread(self):
speaker = espeakng.Speaker()
self.get_logger().info('初始化语音引擎...')
speaker.voice = 'zh'
self.get_logger().info('语音引擎初始化完成,开始朗读小说内容...')
while rclpy.ok() :
if self.novels_queue_.qsize() > 0:
self.get_logger().info('检测到朗读队列中有小说内容,开始朗读...')
text=self.novels_queue_.get()
self.get_logger().info(f'正在朗读小说内容:{text}')
speaker.say(text)
speaker.wait()
self.get_logger().info('小说内容朗读完成')
else:
time.sleep(1)
self.get_logger().info('朗读队列为空,等待新的小说内容...')
# 等待一段时间再检查队列,避免忙等待
def main(args=None):
rclpy.init(args=args)
node = NovelSubNode("novel_read")
rclpy.spin(node)
rclpy.shutdown()
运行到,while rclpy.ok() :之后的代码都执行不下去。后来把代码重打之后,内容可执行。
二、发现订阅者队列,还是接收不了数据
我就对代码的内容重新运行,但是订阅者代码没问题,找了2小时,由于订阅者和发布者之间数据是具有传递关系。
三、检查发布者代码问题
虽然在一开始运行发布者demo是可以运行的,但还是发现变量命名的问题(无关痛痒)。
后来发现两端的传输数据格式有问题。
四、若你实在找不到问题
把你的项目代码之间传到ai,这里笔者用豆包,一定一定要把代码放入,不然干问效率很低。笔者就犯了此错误,已记住。还有就是不要太相信vscode的代码补齐,在疏忽下很容易犯错误。