最近有个需求,用多线程比较合适,但是我需要每个线程的返回值,这就需要我在threading.Thread的基础上进行封装

import threading

class MyThread(threading.Thread):

def __init__(self,func,args=()):

super(MyThread,self).__init__()

self.func = func

self.args = args

def run(self):

self.result = self.func(*self.args)

def get_result(self):

try:

return self.result # 如果子线程不使用join方法,此处可能会报没有self.result的错误

except Exception:

return None

def foo(a,b,c):

time.sleep(1)

print a*2,b*2,c*2,

return a*2,b*2,c*2

st = time.time()

li = []

for i in xrange(4):

t = MyThread(foo,args=(i,i+1,i+2))

li.append(t)

t.start()

for t in li:

t.join() # 一定要join,不然主线程比子线程跑的快,会拿不到结果

print t.get_result()

et = time.time()

print et - st

执行结果

0 2 4 (0, 2, 4)

4 6 8 2 4 6 (2, 4, 6)

(4, 6, 8)

6 8 10 (6, 8, 10)

1.00200009346

元组中的结果是函数foo的返回值,至于结果为什么这么乱,我猜,是因为各子线程foo的print和主线程print get_result()一起抢占系统资源造成。

下面介绍下python获得子线程的返回值,具体代码如下所示:

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 先进后出(类似栈),优先级队列(由单独的优先级参数决定顺序)。使用队列可以实现简单 生产者 – 消费者 模型

总结

以上所述是小编给大家介绍的python获取多线程及子线程的返回值,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

本文标题: python获取多线程及子线程的返回值

本文地址: http://www.cppcns.com/jiaoben/python/211160.html

python多线程返回值_python获取多线程及子线程的返回值相关推荐

  1. python dataframe取列名_python – 获取列名在DataFrame中按其值排序

    我有一个庞大的数据框,我想创建一个字典.字典的键将是行的索引,值将是按该行中的值(降序)排序的数据帧的列名列表.考虑以下示例: df= 23 45 12 3 6 45 0.2 1 0.12 0.5 0 ...

  2. 怎么优雅的在主线程获取子线程的返回值

    今天面试被面试官问道怎么自己实现主线程获取到子线程的返回值,且要优雅不能使用静态变量 方法一:使用FutureTask和Callable来实现 class Test{public static voi ...

  3. python web框架 多线程和多进程_python的多线程和多进程(一)

    在进入主题之前,我们先学习一下并发和并行的概念: --并发:在操作系统中,并发是指一个时间段中有几个程序都处于启动到运行完毕之间,且这几个程序都是在同一个处理机上运行.但任一时刻点上只有一个程序在处理 ...

  4. python 多线程 廖雪峰_python中多线程与多进程中的数据共享问题

    之前在写多线程与多进程的时候,因为一般情况下都是各自完成各自的任务,各个子线程或者各个子进程之前并没有太多的联系,如果需要通信的话我会使用队列或者数据库来完成,但是最近我在写一些多线程与多进程的代码时 ...

  5. 关于python的多线程和多进程_Python的多线程和多进程

    (1)多线程的产生并不是因为发明了多核CPU甚至现在有多个CPU+多核的硬件,也不是因为多线程CPU运行效率比单线程高.单从CPU的运行效率上考虑,单任务进程及单线程效率是最高的,因为CPU没有任何进 ...

  6. python函数参数学习_python学习笔记-11.函数参数和返回值进阶

    1. 函数参数和返回值的作用 函数根据有没有参数以及有没有返回值,可以相互组合,共有4种形式: 无参数,无返回值 无参数,有返回值 有参数,无返回值 有参数,有返回值 定义函数时,是否接收参数,或者是 ...

  7. python提取矩阵元素_python获取array中指定元素的示例

    python获取array中指定元素的示例 对于array,如2-D的array,如何取指定元素 设array为3*10的shape s = array([[ 0, 1, 2, 3, 4, 5, 6, ...

  8. python excel sheet个数_python得到一个excel的全部sheet标签值方法

    python读取excel莫个页签sheets()行数,并且获取里在线分享等,哪位好心人士对于python操作excel熟练请帮忙解 不要在表达爱时那么无力,却又在表达伤害时如此锋利. 如何返使用xl ...

  9. python画画零基础_Python获取英雄联盟皮肤原画:新手玩家们都懵了!

    本爬虫是为了经验交流,喜欢博主的读者,可以点个关注~,更多精彩内容* 爬虫过程 * 分析网页 * 获取每一位英雄的ID值 * 分析原画网页 结语 前言 在本次的爬虫教程的过程中,我也会分享给大家一些简 ...

最新文章

  1. 17.电话号码的组合
  2. 模拟滤波器和数字滤波器
  3. php基础知识【oop/mvc/orm/aop】
  4. 详解/etc/fstab文件内容
  5. Windows Phone 8本地化多语言支持
  6. Silverlight+WCF 新手实例 象棋 介绍II(九)
  7. 【PLSQL】过程procedure形参和参数
  8. 电感式传感器工作原理与电感式传感器应用案例-博扬智能
  9. 线性时间选择(TOP K)
  10. 如何通过波形解析can总线数据
  11. 重试神器Retryer
  12. 自然语言处理(七)——n元语法模型计算句子出现概率
  13. “启用宏的幻灯片”是什么意思
  14. 安装scikit-learn问题
  15. 大学英语B-必考词汇400个
  16. 图解IFRS9 金融工具(8)减值准备规则比较
  17. android百度天气接口api接口,百度天气接口api
  18. [Iterview English] Dimission and Employ
  19. web 微信与基于node的微信机器人实现
  20. 【知识卡片】机器学习模型 都需要标准化、归一化吗?什么时候不需要标准化、归一化

热门文章

  1. java获取数组穷举_请教一下两个数组各取一个元素生成新的数组的穷举算法设计?...
  2. java 数组中某个数出现的概率_剑指Offer解题报告(Java版)——排序数组中某个数的个数 38...
  3. java 加密服务器_Javascript端加密java服务端解密
  4. 克隆需要验证_GeneCopoeia基因克隆
  5. 拆解飞机黑匣子,看看内部构造、PCB及芯片
  6. 面试官:“你大学做过真实项目吗?”
  7. Java接口有时有结果 有时没有_《Java程序员面试笔试宝典》之为什么Java中有些接口没有任何方法...
  8. 天骄2 mysql错误_凤舞天骄一键版和钟隐3合1版的大多数问题解决方案
  9. linux ftp 553,修复使用vsftp出错553 Could not create file的有效方法
  10. toft 测试用例rat_一篇文章详述配对测试的测试用例设计!强烈建议收藏