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,重寫(xiě) 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è)文件夾名稱(chēng)
在?Python?中,解析路徑字符串并獲取每個(gè)文件夾的名稱(chēng)是一項(xiàng)常見(jiàn)的任務(wù),這篇文章主要為大家詳細(xì)介紹了Python解析路徑字符串的具體方法,希望對(duì)大家有所幫助2024-04-04
Python的集合類(lèi)型之set和frozenset詳解
這篇文章主要為大家詳細(xì)介紹了Python的集合類(lèi)型之set和frozenset,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2022-03-03
python函數(shù)裝飾器構(gòu)造和參數(shù)傳遞
這篇文章主要介紹了python函數(shù)裝飾器構(gòu)造和參數(shù)傳遞,下面通過(guò)一個(gè)小案例來(lái)簡(jiǎn)單的理解什么是裝飾器,需要的小伙伴可以參考一下2022-03-03
Python實(shí)現(xiàn)希爾排序,歸并排序和桶排序的示例代碼
希爾、歸并、快速排序算法可歸為同一類(lèi),它們的共同點(diǎn)都是建立在分治思想之上。把大問(wèn)題分拆成小問(wèn)題,解決所有小問(wèn)題后,再合并每一個(gè)小問(wèn)題的結(jié)果,最終得到對(duì)原始問(wèn)題的解答。本文將介紹這三種算法的實(shí)現(xiàn)代碼,需要的可以參考一下2022-04-04
python 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

