python多线程中获取函数返回值的三种方法

 

方法一:使用队列

import queue
import threading
import sys
import time

q=queue.Queue()
def func1(x,y):
  func_name = sys._getframe().f_code.co_name # 获取函数名
  print("%s run ....." % func_name)
  q.put((x+y,func_name))

def func2(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=[]
  t1=threading.Thread(target=func1,name="thread1",args=(10,5))
  t2=threading.Thread(target=func2,name="thread2",args=(20,1))
  print('*'*20)
  t1.start()
  t2.start()
  t1.join()
  t2.join()
  while not q.empty():# 队列为空返回True,反之False
      result.append(q.get())
  for item in result:
      if item[1] == func1.__name__:
          print("%s return value is: %s" %(item[1],item[0]))
      elif item[1] == func2.__name__:
          print("%s return value is: %s" %(item[1],item[0]))

运行结果:
********************
func1 run .....
func2 run ....
func1 return value is: 15
func2 return value is: 19

 

方法二: 封装 threading.Thread,重写 run 方法

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
      except Exception:
          return None
def foo(a,b,c):
  time.sleep(1)
  return a*2,b*2,c*2
li = []
for i in range(4):
  t=mythread(foo,args=(i,i+1,i+2))
  li.append(t)
  t.start()
for t in li:
  t.join()
  print(t.get_result())

# 运行结果
(0, 2, 4)
(2, 4, 6)
(4, 6, 8)
(6, 8, 10)

 

方法三:使用进程池

def func(msg):
  print("msg:",msg)
  time.sleep(3)
  print("end")
  return "done" + msg
if __name__ == "__main__":
  pool = multiprocessing.Pool(processes=4)
  result = []
  for i in range(3):
      msg = "hello %d" %i
      result.append(pool.apply_async(func,(msg,)))
  pool.close()
  pool.join()
  for res in result:
      print(res)
      print(":::",res.get())
# 运行结果
msg: hello 0
msg: hello 1
msg: hello 2
end
end
end
<multiprocessing.pool.ApplyResult object at 0x0000027BF6B3F0D0>
::: donehello 0
<multiprocessing.pool.ApplyResult object at 0x0000027BF6F4FDF0>
::: donehello 1
<multiprocessing.pool.ApplyResult object at 0x0000027BF6F4FDC0>
::: donehello 2

关于python多线程中获取函数返回值的三种方法的文章就介绍至此,更多相关python多线程中获取函数返回值内容请搜索编程宝库以前的文章,希望以后支持编程宝库

本文介绍python统计词频的几种方法,供大家参考 方法一:运用集合去重方法 def word_count1(words,n): word_list = [] for word in set ...