(更新python3.x 版)python 多线程中子线程和主线程相互通信

这篇博客介绍了如何在Python3.x中实现多线程环境下,子线程与主线程之间的通信。通过使用队列对象实现FIFO特性,每个子线程在完成任务后将消息放入队列,主线程则通过循环读取队列来获取子线程的状态。文中还强调了对原创内容的尊重和版权保护。
摘要由CSDN通过智能技术生成

声明:最近发现许多博文,内容和本文完全一致,但是并不署名为转载,或者复制到其他平台后又转载到CSDN平台;并且还有人将我的文章做成PDF文档,在下载区卖C币(python多线程中子线程和主线程相互通信方法_-互联网文档类资源-CSDN下载),再此我严正声明,请尊重我的劳动成果,转载请注明原文出处,对于拿我的文章去换C币的行为严重鄙视!!!

需求:主线程开启了多个线程去干活,每个线程需要完成的时间不同,但是在干完活以后都要通知给主线程

下面上代码:

# !/usr/bin/python
# coding:utf8
'''
多线程和queue配合使用,实现子线程和主线程相互通信的例子
'''
import threading
import queue
import
Python 中,线程调用线程的方法可以使用 Queue 模块来实现。具体步骤如下: 1. 在线程中创建一个 Queue 对象,并将需要调用的方法和参数封装成一个元组,放入队列中。 2. 在线程中,通过 Queue.get() 方法获取队列中的元组,其中包含需要调用的方法和参数。 3. 线程通过调用该方法,并将参数传递给方法。 4. 如果需要在线程中获得该方法的返回值,可以将返回值封装成一个元组,放入另一个队列中。 5. 在线程中,通过 Queue.get() 方法获取线程中的返回值元组,其中包含方法的返回值。 下面是一个简单的示例代码: ```python import threading import queue def main_thread_method(arg): print(f"Main thread method called with arg {arg}") def worker_thread(queue): while True: # 阻塞等待线程传来的任务 task = queue.get() method, args = task # 调用方法,并将返回值封装成元组返回给线程 ret = method(*args) queue.put(ret) if __name__ == "__main__": # 启动线程 q = queue.Queue() t = threading.Thread(target=worker_thread, args=(q,)) t.start() # 在线程中将任务加入队列 q.put((main_thread_method, ("hello",))) # 等待线程返回结果 ret = q.get() print(f"Received result from worker thread: {ret}") ``` 在此示例中,线程调用 main_thread_method 方法,并将参数 "hello" 封装成一个任务元组加入队列中。线程从队列中获取任务,并执行该方法,将返回值封装成元组后再次放入队列中。线程从队列中获取返回值元组,其中包含方法的返回值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值