- import sys
- import threading
- import Queue
- q = Queue.Queue()
- def worker1(x, y):
- func_name = sys._getframe().f_code.co_name
- print "%s run ..." % func_name
- q.put((x + y, func_name))
- def worker2(x, y):
- func_name = sys._getframe().f_code.co_name
- print "%s run ...." % func_name
- q.put((x - y, func_name))
- if __name__ == '__main__':
- result = list()
- t1 = threading.Thread(target=worker1, name='thread1', args=(10, 5, ))
- t2 = threading.Thread(target=worker2, name='thread2', args=(20, 1, ))
- print '-' * 50
- t1.start()
- t2.start()
- t1.join()
- t2.join()
- while not q.empty():
- result.append(q.get())
- for item in result:
- if item[1] == worker1.__name__:
- print "%s 's return value is : %s" % (item[1], item[0])
- elif item[1] == worker2.__name__:
- print "%s 's return value is : %s" % (item[1], item[0])
这是目前最主流的获取线程数据的方法。使用 Queue 库创建队列实例,用来储存和传递线程间的数据。Python 的队列是线程安全的,也就是说多个线程同时访问一个队列也不会有冲突。Python 队列有三种 FIFO 先进先出,FILO 先进后出(类似栈),优先级队列(由单独的优先级参数决定顺序)。使用队列可以实现简单 生产者 – 消费者 模型