欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python使用threading獲取線(xiàn)程函數(shù)返回值的實(shí)現(xiàn)方法

 更新時(shí)間:2017年11月15日 17:17:35   作者:QualitySong  
這篇文章主要介紹了python使用threading獲取線(xiàn)程函數(shù)返回值的實(shí)現(xiàn)方法,需要的朋友可以參考下

threading用于提供線(xiàn)程相關(guān)的操作,線(xiàn)程是應(yīng)用程序中工作的最小單元。python當(dāng)前版本的多線(xiàn)程庫(kù)沒(méi)有實(shí)現(xiàn)優(yōu)先級(jí)、線(xiàn)程組,線(xiàn)程也不能被停止、暫停、恢復(fù)、中斷。

threading模塊提供的類(lèi): 

  Thread, Lock, Rlock, Condition, [Bounded]Semaphore, Event, Timer, local。

threading 模塊提供的常用方法:

  threading.currentThread(): 返回當(dāng)前的線(xiàn)程變量。

  threading.enumerate(): 返回一個(gè)包含正在運(yùn)行的線(xiàn)程的list。正在運(yùn)行指線(xiàn)程啟動(dòng)后、結(jié)束前,不包括啟動(dòng)前和終止后的線(xiàn)程。

  threading.activeCount(): 返回正在運(yùn)行的線(xiàn)程數(shù)量,與len(threading.enumerate())有相同的結(jié)果。

threading 模塊提供的常量:

  threading.TIMEOUT_MAX 設(shè)置threading全局超時(shí)時(shí)間。

好了,正文開(kāi)始:

最近需要用python寫(xiě)一個(gè)環(huán)境搭建工具,多線(xiàn)程并行對(duì)環(huán)境各個(gè)部分執(zhí)行一些操作,并最終知道這些并行執(zhí)行的操作是否都執(zhí)行成功了,也就是判斷這些操作函數(shù)的返回值是否為0。但是threading并沒(méi)有顯式的提供獲取各個(gè)線(xiàn)程函數(shù)返回值的方法,只好自己動(dòng)手,下面就介紹一下自己的實(shí)現(xiàn)方式。

一開(kāi)始考慮到執(zhí)行的操作可能有很多,而且后續(xù)會(huì)不斷補(bǔ)充,因此先寫(xiě)了一個(gè)通用的多線(xiàn)程執(zhí)行類(lèi),封裝線(xiàn)程操作的基本方法,如下:

import threading
class MyThread(object):
  def __init__(self, func_list=None):
  #所有線(xiàn)程函數(shù)的返回值匯總,如果最后為0,說(shuō)明全部成功
    self.ret_flag = 0
    self.func_list = func_list
    self.threads = []
  def set_thread_func_list(self, func_list):
    """
    @note: func_list是一個(gè)list,每個(gè)元素是一個(gè)dict,有func和args兩個(gè)參數(shù)
    """
    self.func_list = func_list
  def start(self):
    """
    @note: 啟動(dòng)多線(xiàn)程執(zhí)行,并阻塞到結(jié)束
    """
    self.threads = []
    self.ret_flag = 0
    for func_dict in self.func_list:
      if func_dict["args"]:
        t = threading.Thread(target=func_dict["func"], args=func_dict["args"])
      else:
        t = threading.Thread(target=func_dict["func"])
      self.threads.append(t)
    for thread_obj in self.threads:
      thread_obj.start()
    for thread_obj in self.threads:
      thread_obj.join()
  def ret_value(self):
    """
    @note: 所有線(xiàn)程函數(shù)的返回值之和,如果為0那么表示所有函數(shù)執(zhí)行成功
    """
    return self.ret_flag

MyThread類(lèi)會(huì)接受一個(gè)func_list參數(shù),每個(gè)元素是一個(gè)dict,有func和args兩個(gè)key,func是真正要執(zhí)行的函數(shù)引用,args是函數(shù)的參數(shù)。其中最主要的方法是start方法,會(huì)多線(xiàn)程執(zhí)行每個(gè)func,然后一直等到所有線(xiàn)程都執(zhí)行結(jié)束后退出。接下來(lái)的關(guān)鍵就是如何對(duì)self.ret_flag設(shè)置正確的值,以判斷所有的線(xiàn)程函數(shù)是否都返回0了。

我的實(shí)現(xiàn)是,在MyThread class中寫(xiě)一個(gè)方法trace_func,作為直接的線(xiàn)程函數(shù),這個(gè)trace_func中執(zhí)行真正需要執(zhí)行的函數(shù),從而可以獲取到該函數(shù)的返回值,設(shè)置給self.ret_flag。

這個(gè)trace_func的第一參數(shù)是要執(zhí)行的func引用,后面是這個(gè)func的參數(shù),具體代碼如下:

def trace_func(self, func, *args, **kwargs):
  """
  @note:替代profile_func,新的跟蹤線(xiàn)程返回值的函數(shù),對(duì)真正執(zhí)行的線(xiàn)程函數(shù)包一次函數(shù),以獲取返回值
  """
  ret = func(*args, **kwargs)
  self.ret_flag += ret

這樣就需要修改start方法中Thread函數(shù)的設(shè)置,代碼如下:

def start(self):
  """
  @note: 啟動(dòng)多線(xiàn)程執(zhí)行,并阻塞到結(jié)束
  """
  self.threads = []
  self.ret_flag = 0
  for func_dict in self.func_list:
    if func_dict["args"]:
      new_arg_list = []
      new_arg_list.append(func_dict["func"])
      for arg in func_dict["args"]:
        new_arg_list.append(arg)
      new_arg_tuple = tuple(new_arg_list)
      t = threading.Thread(target=self.trace_func, args=new_arg_tuple)
    else:
      t = threading.Thread(target=self.trace_func, args=(func_dict["func"],))
    self.threads.append(t)
  for thread_obj in self.threads:
    thread_obj.start()
  for thread_obj in self.threads:
    thread_obj.join()

這樣能夠成功獲得返回值了,實(shí)驗(yàn):

def func1(ret_num):
  print "func1 ret:%d" % ret_num
  return ret_num
def func2(ret_num):
  print "func2 ret:%d" % ret_num
  return ret_num
def func3():
  print "func3 ret:100"
  return 100
mt = MyThread()
g_func_list = []
g_func_list.append({"func":func1,"args":(1,)})
g_func_list.append({"func":func2,"args":(2,)})
g_func_list.append({"func":func3,"args":None})
mt.set_thread_func_list(g_func_list)
mt.start()
print "all thread ret : %d" % mt.ret_flag

最后的輸出結(jié)果

func1 ret:1
func2 ret:2
func3 ret:100
all thread ret : 103

總結(jié)

以上所述是小編給大家介紹的python使用threading獲取線(xiàn)程函數(shù)返回值的實(shí)現(xiàn)方法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • pytorch在fintune時(shí)將sequential中的層輸出方法,以vgg為例

    pytorch在fintune時(shí)將sequential中的層輸出方法,以vgg為例

    今天小編就為大家分享一篇pytorch在fintune時(shí)將sequential中的層輸出方法,以vgg為例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-08-08
  • 解決python3中解壓zip文件是文件名亂碼的問(wèn)題

    解決python3中解壓zip文件是文件名亂碼的問(wèn)題

    下面小編就為大家分享一篇解決python3中解壓zip文件是文件名亂碼的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-03-03
  • 最新解決'nvidia-smi' 不是內(nèi)部或外部命令也不是可運(yùn)行的程序

    最新解決'nvidia-smi' 不是內(nèi)部或外部命令也不是可運(yùn)行的程序

    使用cmd查看電腦顯卡的信息,調(diào)用nvidia-smi查看顯卡使用情況報(bào)錯(cuò),提示'nvidia-smi' 不是內(nèi)部或外部命令,也不是可運(yùn)行的程序,本文給大家分享完美解決方案,感興趣的朋友跟隨小編一起看看吧
    2023-01-01
  • django限制匿名用戶(hù)訪(fǎng)問(wèn)及重定向的方法實(shí)例

    django限制匿名用戶(hù)訪(fǎng)問(wèn)及重定向的方法實(shí)例

    這篇文章主要給大家介紹了關(guān)于django限制匿名用戶(hù)訪(fǎng)問(wèn)及重定向的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-02-02
  • 利用python?OpenCV去除視頻水印

    利用python?OpenCV去除視頻水印

    這篇文章主要介紹了利用python?OpenCV去除視頻水印,下面我們將利用視頻的某一幀將圖片的一些污點(diǎn)去掉,代碼先從視頻中導(dǎo)出一幀圖片,然后統(tǒng)計(jì)需要?jiǎng)h除按鈕的坐標(biāo)位置,然后再對(duì)視頻中的每一幀圖像做處理的函數(shù),下面操作過(guò)程需要的小伙伴可以參考一下
    2022-02-02
  • Python實(shí)現(xiàn)統(tǒng)計(jì)圖像連通域的示例詳解

    Python實(shí)現(xiàn)統(tǒng)計(jì)圖像連通域的示例詳解

    這篇文章主要為大家詳細(xì)介紹了如何利用Python實(shí)現(xiàn)統(tǒng)計(jì)圖像連通域的功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起了解一下
    2023-04-04
  • 如何在Python項(xiàng)目中引入日志

    如何在Python項(xiàng)目中引入日志

    在開(kāi)發(fā)一些大型項(xiàng)目的時(shí)候,都會(huì)使用日志來(lái)記錄項(xiàng)目運(yùn)行時(shí)產(chǎn)生的信息,以備出錯(cuò)時(shí)定位分析和從日志信息中提取數(shù)據(jù)統(tǒng)計(jì)分析等。在 Python 中使用 logging 內(nèi)置模塊即可對(duì)項(xiàng)目進(jìn)行日志的配置。
    2021-05-05
  • Python中*args與**kwargs的高級(jí)應(yīng)用指南

    Python中*args與**kwargs的高級(jí)應(yīng)用指南

    在Python編程中,*args和**kwargs是兩個(gè)非常強(qiáng)大的功能,它們?cè)试S開(kāi)發(fā)者構(gòu)建更加靈活和可擴(kuò)展的函數(shù),下面就跟隨小編一起來(lái)看看它的具體應(yīng)用吧
    2024-03-03
  • python如何保證輸入鍵入數(shù)字的方法

    python如何保證輸入鍵入數(shù)字的方法

    今天小編就為大家分享一篇python如何保證輸入鍵入數(shù)字的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-08-08
  • 解決pytorch DataLoader num_workers出現(xiàn)的問(wèn)題

    解決pytorch DataLoader num_workers出現(xiàn)的問(wèn)題

    今天小編就為大家分享一篇解決pytorch DataLoader num_workers出現(xiàn)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-01-01

最新評(píng)論