Python 3基础教程40-队列-Queue

来源:互联网 发布:西西软件网 编辑:程序博客网 时间:2024/06/05 04:21

       本文来介绍下队列的基本使用,队列是Python线程中最常用的数据交换方法。Queue是queue模块下的对象,Queue是python标准库中的线程安全的队列(FIFO)实现,提供了一个适用于多线程编程的先进先出的数据结构。本文会用到Queue的put和get方法,put()就是把一个值放入到队列,get()就是从队列取出一个值,看看下面的例子。

import threadingimport timefrom queue import Queuedef job(data,q):    for i in range(len(data)):        data[i] = data[i]**2    # put方法把结果放入队列,这里不能使用return语句    q.put(data)def exampleFuc():    # 新建一个队列    q = Queue()    # 新建一个空的多线程列表    threads = []    # 给出一个数据,到job去计算    data = [[1,2,3],[2,3,4],[3,4,5],[4,5,6]]    # for 循环创建一个多线程,大小根据data[]的大小    for x in range(4):        t = threading.Thread(target=job, args=(data[x], q))        # 启动线程        t.start()        # 把创建线程添加到多线程threads这个列表        threads.append(t)    for each_thread in threads:        each_thread.join()    # 定义一个计算结果列表    results = []    # 把结果分别从队列取出,这里需要取4次    for y in range(4):        # q.get()就是从队列取出结果        results.append(q.get())    # 等所以事情完成,就打印结果列表    print(results)    exampleFuc()
运行计算结果:

============= RESTART: C:\Users\Anthony\Desktop\thread_queue.py =============[[1, 4, 9], [4, 9, 16], [9, 16, 25], [16, 25, 36]]>>> 

0 0