c++ - 如何在python的阻塞的函数中获取变量值
问题描述
目前是使用C++嵌入式的python函数python函数是阻塞式的接收服务器消息直到退出监听才会有返回值监听中收到消息会调用python的一个回调函数,可以获取到收到的消息所以要怎么样来返回消息给C++
EDIT:代码如下callback打印可以打印正确数据,问题是这里用pika库写的rabbitMQ 的client就是为了不用rabbitMQ的C库现在有一种考虑就是再用C写一个python可以调的module然后在回调函数里面调,就是感觉有点丑陋。
#!/usr/bin/env pythonimport pikaimport sysmessage = ''def callback(ch, method, properties, body): message = body print(method.routing_key) return message def consume(): connection = pika.BlockingConnection(pika.ConnectionParameters(host=’localhost’)) channel = connection.channel() result = channel.queue_declare(exclusive=True) queue_name = result.method.queue channel.queue_bind(exchange=’normalEx’, routing_key=’remote’, queue=queue_name) print(’ [*] Waiting for logs. To exit press CTRL+C’) channel.basic_consume(callback, queue=queue_name, no_ack=True) channel.start_consuming()
问题解答
回答1:处于堵塞的函数, 都需要等到收到数据或者等待超时才能返回的, 如果你想要快点返回, 就采用不堵塞的方式咯,只不过这样会比较蛋疼
相关文章:
1. javascript - h5微信中怎么禁止横屏2. 为什么我ping不通我的docker容器呢???3. python - 怎么查看网址做的是什么反爬虫4. node.js - webpack required打包问题5. boot2docker无法启动6. css - div设置float:left后高度设置自动会无效 ?7. 关docker hub上有些镜像的tag被标记““This image has vulnerabilities””8. nignx - docker内nginx 80端口被占用9. docker - 各位电脑上有多少个容器啊?容器一多,自己都搞混了,咋办呢?10. docker-compose中volumes的问题

网公网安备