python多線程中獲取函數(shù)返回值的三種方法
方法一:使用隊(duì)列
import queue import threading import sys import time q=queue.Queue() def func1(x,y): func_name = sys._getframe().f_code.co_name # 獲取函數(shù)名 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():# 隊(duì)列為空返回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]))
運(yùn)行結(jié)果:
********************
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()) # 運(yùn)行結(jié)果 (0, 2, 4) (2, 4, 6) (4, 6, 8) (6, 8, 10)
方法三:使用進(jìn)程池
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()) # 運(yùn)行結(jié)果 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
到此這篇關(guān)于python多線程中獲取函數(shù)返回值的三種方法的文章就介紹到這了,更多相關(guān)python多線程中獲取函數(shù)返回值內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python實(shí)現(xiàn)解析路徑字符串并獲取每個(gè)文件夾名稱
在?Python?中,解析路徑字符串并獲取每個(gè)文件夾的名稱是一項(xiàng)常見(jiàn)的任務(wù),這篇文章主要為大家詳細(xì)介紹了Python解析路徑字符串的具體方法,希望對(duì)大家有所幫助2024-04-04python函數(shù)裝飾器構(gòu)造和參數(shù)傳遞
這篇文章主要介紹了python函數(shù)裝飾器構(gòu)造和參數(shù)傳遞,下面通過(guò)一個(gè)小案例來(lái)簡(jiǎn)單的理解什么是裝飾器,需要的小伙伴可以參考一下2022-03-03Python實(shí)現(xiàn)希爾排序,歸并排序和桶排序的示例代碼
希爾、歸并、快速排序算法可歸為同一類,它們的共同點(diǎn)都是建立在分治思想之上。把大問(wèn)題分拆成小問(wèn)題,解決所有小問(wèn)題后,再合并每一個(gè)小問(wèn)題的結(jié)果,最終得到對(duì)原始問(wèn)題的解答。本文將介紹這三種算法的實(shí)現(xiàn)代碼,需要的可以參考一下2022-04-04python Pandas如何對(duì)數(shù)據(jù)集隨機(jī)抽樣
這篇文章主要介紹了python Pandas如何對(duì)數(shù)據(jù)集隨機(jī)抽樣,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07