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

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

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

相关推荐
szccyw01 分钟前
mysql如何限制特定存储过程执行权限_MySQL存储过程安全访问
jvm·数据库·python
小白学大数据7 分钟前
Python 自动化爬取网易云音乐歌手歌词实战教程
爬虫·python·okhttp·自动化
REDcker34 分钟前
浏览器端Web程序性能分析与优化实战 DevTools指标与工程清单
开发语言·前端·javascript·vue·ecmascript·php·js
dllmayday43 分钟前
Linux 上用终端连接 WiFi
linux·服务器·windows
OBiO20131 小时前
Cell | 突破AAV载体容量限制!路中华/姜玉武/刘太安团队开发AAVLINK系统实现大基因递送
笔记
风之所往_2 小时前
Python 3.0 新特性全面总结
python
2401_882273722 小时前
如何在 CSS 中正确加载本地 JPG 背景图片
jvm·数据库·python
Lucas_coding2 小时前
【Claude Code Router】 Claude Code 兼容 OpenAI 格式 API, Claude code 接入本地部署模型
人工智能·python
测试员周周2 小时前
【AI测试系统】第5篇:从 Archon 看 AI 工程化落地:为什么"确定性编排+AI 弹性智能"是终局?
人工智能·python·测试
我命由我123452 小时前
Kotlin 开发 - lateinit 关键字
android·java·开发语言·kotlin·android studio·android-studio·android runtime