下面是一个示例代码,演示了如何按顺序处理请求:
import time
from queue import Queue
from threading import Thread
# 定义一个请求处理函数
def process_request(request):
print("Processing request:", request)
time.sleep(1) # 模拟处理请求的耗时操作
print("Request processed:", request)
# 定义一个线程函数,用于处理请求队列中的请求
def handle_requests(request_queue):
while True:
request = request_queue.get() # 从队列中获取请求
process_request(request) # 处理请求
request_queue.task_done() # 标记请求处理完成
# 创建一个请求队列
request_queue = Queue()
# 启动多个线程,用于处理请求
num_workers = 4
for i in range(num_workers):
worker = Thread(target=handle_requests, args=(request_queue,))
worker.daemon = True # 设置线程为守护线程,即主线程结束时自动退出
worker.start()
# 往请求队列中添加请求
requests = [1, 2, 3, 4, 5]
for request in requests:
request_queue.put(request)
# 等待所有请求处理完成
request_queue.join()
这个示例代码中,首先定义了一个process_request
函数,用于处理请求。然后定义了一个线程函数handle_requests
,该函数会不断地从请求队列中获取请求,然后调用process_request
函数处理请求。
在主程序中,首先创建了一个请求队列request_queue
。然后通过创建多个线程的方式,启动了多个处理请求的线程。接着,将所有的请求依次添加到请求队列中。最后,调用request_queue.join()
等待所有请求处理完成。
这样,所有的请求会按照添加的顺序被依次处理。
下一篇:按顺序处理事件发射器的消息