项目心得——发布者和订阅者问题解决思路

项目心得------发布者和订阅者问题解决思路

在发布者和订阅者项目中,当我运行订阅者的时候,发现订阅者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的代码补齐,在疏忽下很容易犯错误。

相关推荐
wjs20241 小时前
Java 注释
开发语言
Elieal1 小时前
常用的 Linux 命令
linux·运维·服务器
C.L.L1 小时前
Linux中capslock+实现——input-remapper
linux
人道领域1 小时前
JavaWeb从入门到进阶(javaScript)
开发语言·javascript·ecmascript
装不满的克莱因瓶2 小时前
【2026最新 架构环境安装篇三】Docker安装RabbitMQ4.x详细教程
linux·运维·docker·容器·架构·rabbitmq
Hello_Embed2 小时前
RS485 双串口通信 + LCD 实时显示(中断版)
c语言·笔记·单片机·学习·操作系统·嵌入式
chilavert3182 小时前
技术演进中的开发沉思-317 JVM:指令集(下)
开发语言·python
音无八重2 小时前
Linux(Ubuntu)下无法连接ppa.launchpadcontent.net的解决方法
linux·运维·ubuntu
超级大福宝2 小时前
Vim 和 tmux 的常用注意事项
linux·编辑器·vim