在Python中,多线程编程可以通过threading
模块来实现。线程间的通信是指在一个线程中运行的程序需要与其他线程中运行的程序共享数据或信息。Python提供了多种方法来实现线程间的通信,以下是其中的一些常用方法:
Queue
模块:Queue
模块提供了一个线程安全的队列类,可以在多个线程之间传递数据。这是一个简单的例子:
import threading
import queue
import time
def worker(q):
while True:
item = q.get()
if item is None:
break
print(f"Worker: {item}")
time.sleep(1)
q.task_done()
q = queue.Queue()
for i in range(5):
q.put(i)
threads = []
for _ in range(2):
t = threading.Thread(target=worker, args=(q,))
t.start()
threads.append(t)
q.join() # 等待所有任务完成
for _ in range(len(threads)):
q.put(None) # 通知线程退出
for t in threads:
t.join()
Event
模块:Event
模块提供了一个线程同步原语,可以用来通知其他线程某个事件已经发生。这是一个简单的例子:
import threading
import time
def worker(e):
while True:
e.wait() # 等待事件发生
print("Worker: Event occurred")
time.sleep(1)
e = threading.Event()
t = threading.Thread(target=worker, args=(e,))
t.start()
time.sleep(2) # 让工作线程等待一段时间
e.set() # 设置事件,通知工作线程
t.join()
Condition
模块:Condition
模块提供了一个线程同步原语,可以用来在多个线程之间协调对共享资源的访问。这是一个简单的例子:
import threading
import time
class Counter:
def __init__(self):
self.value = 0
self.cond = threading.Condition()
def increment(self):
with self.cond:
self.value += 1
print(f"Counter: {self.value}")
self.cond.notify_all() # 通知所有等待的线程
def worker(counter):
while True:
with counter.cond:
while counter.value == 0:
counter.cond.wait() # 等待计数器变为非零
counter.value -= 1
print(f"Worker: {counter.value}")
counter = Counter()
threads = []
for _ in range(3):
t = threading.Thread(target=worker, args=(counter,))
t.start()
threads.append(t)
for _ in range(10):
counter.increment()
time.sleep(1)
for t in threads:
t.join()
这些方法都可以用来实现线程间的通信。你可以根据具体的需求选择合适的方法。