"""
1、用一个队列来存储数据
2、创建一个专门生产数据的任务函数,循环生产5次数据,每轮循环,往队列中添加20条数据,每循环一轮暂停1秒
3、创建一个专门处理数据的任务函数 循环获取队列中的数据处理,每秒处理4条数据。
4、创建一个线程(或进程)生产数据 ,3个线程(或进程)处理数据
5、统计数据生产并获取完 程序运行的总时长
"""
# ===============多线程实现============================
import time
from queue import Queue
from threading import Thread
q = Queue()
def add_data():
"""生产数据"""
for i in range(5):
for j in range(20):
data = "数据--{}---{}".format(i, j)
q.put(data)
print("【生产数据】{}".format(data))
time.sleep(1)
def handle_data():
"""处理数据"""
while True:
for i in range(4):
try:
data = q.get(timeout=1)
except:
return
else:
print("【处理数据】", data)
q.task_done()
time.sleep(1)
# def handle_data():
# """处理数据"""
# while not q.empty():
# try:
# data = q.get(timeout=1)
# except:
# return
# else:
# q.task_done()
# time.sleep(0.25)
def main():
"""启动函数"""
t1 = Thread(target=add_data)
t1.start()
for i in range(3):
Thread(target=handle_data).start()
# 等待数据生完
t1.join()
# 等待队列中的数据处理完
q.join()
if __name__ == '__main__':
st = time.time()
main()
et = time.time()
print("程序运行总时长:", et - st)
"""
1、用一个队列来存储数据
2、创建一个专门生产数据的任务函数,循环生产5次数据,每轮循环,往队列中添加20条数据,每循环一轮暂停1秒
3、创建一个专门处理数据的任务函数 循环获取队列中的数据处理,每秒处理4条数据。
4、创建一个线程(或进程)生产数据 ,3个线程(或进程)处理数据
5、统计数据生产并获取完 程序运行的总时长
"""
# ===============多线程实现============================
import time
from queue import Queue
from threading import Thread
q = Queue()
def add_data():
"""生产数据"""
for i in range(5):
for j in range(20):
data = "数据--{}---{}".format(i, j)
q.put(data)
print("【生产数据】{}".format(data))
time.sleep(1)
def handle_data():
"""处理数据"""
while True:
for i in range(4):
try:
data = q.get(timeout=1)
except:
return
else:
print("【处理数据】", data)
q.task_done()
time.sleep(1)
def main():
"""启动函数"""
t1 = Thread(target=add_data)
t1.start()
for i in range(3):
Thread(target=handle_data).start()
# 等待数据生完
t1.join()
# 等待队列中的数据处理完
q.join()
if __name__ == '__main__':
st = time.time()
main()
et = time.time()
print("程序运行总时长:", et - st)
进程与线程的经典练习题
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
相关阅读更多精彩内容
- C语言是面向过程的,而C++是面向对象的 C和C++的区别: C是一个结构化语言,它的重点在于算法和数据结构。C程...
- 题目 写两个线程,一个线程打印1-52,另一个线程打印A-Z,打印顺序为12A34B56C......5152Z。...