亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

python 在threading中如何處理主進程和子線程的關系

 更新時間:2020年04月25日 14:16:53   作者:chen_999876  
這篇文章主要介紹了python 在threading中如何處理主進程和子線程的關系,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

之前用python的多線程,總是處理不好進程和線程之間的關系。后來發(fā)現(xiàn)了join和setDaemon函數(shù),才終于弄明白。下面總結(jié)一下。

1.使用join函數(shù)后,主進程會在調(diào)用join的地方等待子線程結(jié)束,然后才接著往下執(zhí)行。

join使用實例如下:

import time
import random
import threading
 
class worker(threading.Thread):
  def __init__(self): 
    threading.Thread.__init__(self) 
  def run(self):
    t = random.randint(1,10)
    time.sleep(t)
    print "This is " + self.getName() + ";I sleep %d second."%(t)
    
tsk = []
for i in xrange(0,5):
  time.sleep(0.1)
  thread = worker()
  thread.start()
  tsk.append(thread)
for tt in tsk:
  tt.join()
print "This is the end of main thread."

運行結(jié)果如下:

# python testjoin.py 
This is Thread-3;I sleep 2 second.
This is Thread-1;I sleep 4 second.
This is Thread-2;I sleep 7 second.
This is Thread-4;I sleep 7 second.
This is Thread-5;I sleep 7 second.
This is the end of main thread.

這里創(chuàng)建了5個子線程,每個線程隨機等待1-10秒后打印退出;主線程分別等待5個子線程結(jié)束。最后結(jié)果是先顯示各個子線程,再顯示主進程的結(jié)果。

2. 如果使用的setDaemon函數(shù),則與join相反,主進程結(jié)束的時候不會等待子線程。

setDaemon函數(shù)使用實例:

import time
import random
import threading
 
class worker(threading.Thread):
  def __init__(self): 
    threading.Thread.__init__(self) 
  def run(self):
    t = random.randint(1,10)
    time.sleep(t)
    print "This is " + self.getName() + ";I sleep %d second."%(t)
    
tsk = []
for i in xrange(0,5):
  time.sleep(0.1)
  thread = worker()
  thread.setDaemon(True)
  thread.start()
  tsk.append(thread)
print "This is the end of main thread."

這里設置主進程為守護進程,當主進程結(jié)束的時候,子線程被中止

運行結(jié)果如下:

#python testsetDaemon.py
This is the end of main thread.

3、如果沒有使用join和setDaemon函數(shù),則主進程在創(chuàng)建子線程后,直接運行后面的代碼,主程序一直掛起,直到子線程結(jié)束才能結(jié)束。

import time
import random
import threading
 
class worker(threading.Thread):
  def __init__(self): 
    threading.Thread.__init__(self) 
  def run(self):
    t = random.randint(1,10)
    time.sleep(t)
    print "This is " + self.getName() + ";I sleep %d second."%(t)
    
tsk = []
for i in xrange(0,5):
  time.sleep(0.1)
  thread = worker()
  thread.start()
  tsk.append(thread)
print "This is the end of main thread."

運行結(jié)果如下:

# python testthread.py 
This is the end of main thread.
This is Thread-4;I sleep 1 second.
This is Thread-3;I sleep 7 second.
This is Thread-5;I sleep 7 second.
This is Thread-1;I sleep 10 second.
This is Thread-2;I sleep 10 second.

補充知識:Python Thread和Process對比

原因:進程和線程的差距(方向不同,之針對這個實例)

# coding=utf-8
import logging
import multiprocessing
import os
import time
from threading import Thread

logging.basicConfig(
  level=logging.INFO,
  format="%(asctime)s 【 %(process)d 】 %(processName)s %(message)s"
)


def func (i):
  # logging.info(f'子:{os.getpid()},\t{i}')
  return f'子:{os.getpid()},\t{i}'


def main (ctx):
  start01 = time.time()
  ts = [Thread(target=func, args=(i,)) for i in range(100)]
  [t.start() for t in ts]
  [t.join() for t in ts]
  end01 = time.time() - start01
  logging.info(f"線程花費的時間:{end01}秒")
  
  start02 = time.time()
  ps = [ctx.Process(target=func, args=(i,)) for i in range(100)]
  [p.start() for p in ps]
  [p.join() for p in ps]
  end02 = time.time() - start02
  logging.info(f"進程花費的時間:{end02}秒")


if __name__ == '__main__':
  # windows 啟動方式
  multiprocessing.set_start_method('spawn')
  # 獲取上下文
  ctx = multiprocessing.get_context('spawn')
  # 檢查這是否是凍結(jié)的可執(zhí)行文件中的偽分支進程。
  ctx.freeze_support()
  main(ctx)

輸出:

2019-10-06 14:17:22,729 【 7412 】 MainProcess 線程花費的時間:0.012967586517333984秒
2019-10-06 14:17:25,671 【 7412 】 MainProcess 進程花費的時間:2.9418249130249023秒

以上這篇python 在threading中如何處理主進程和子線程的關系就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • Python中的localtime()方法使用詳解

    Python中的localtime()方法使用詳解

    這篇文章主要介紹了Python中的localtime()方法使用詳解,是Python入門學習的基礎知識,需要的朋友可以參考下
    2015-05-05
  • Python批量實現(xiàn)Word/EXCEL/PPT轉(zhuǎn)PDF

    Python批量實現(xiàn)Word/EXCEL/PPT轉(zhuǎn)PDF

    在日常辦公和文檔處理中,有時我們需要將多個Word文檔、Excel表格或PPT演示文稿轉(zhuǎn)換為PDF文件,本文將介紹如何使用Python編程語言批量實現(xiàn)將多個Word、Excel和PPT文件轉(zhuǎn)換為PDF文件,需要的可以參考下
    2023-09-09
  • pycharm全局修改方式

    pycharm全局修改方式

    這篇文章主要介紹了pycharm全局修改方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • python中的format是什么意思,format怎么用

    python中的format是什么意思,format怎么用

    這篇文章主要介紹了python中的format是什么意思?format怎么用?今天小編就為大家介紹一下format用法,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Python實現(xiàn)基于Fasttext的商品評論數(shù)據(jù)分類的操作流程

    Python實現(xiàn)基于Fasttext的商品評論數(shù)據(jù)分類的操作流程

    這篇文章主要介紹了Python實現(xiàn)基于Fasttext的商品評論數(shù)據(jù)分類,今天使用的fasttext更像是一個集成的庫,把向量化和分類一起做掉了,這個對于使用層面來講就更方便了一些,需要的朋友可以參考下
    2022-06-06
  • Flask運用Xterm實現(xiàn)交互終端的示例詳解

    Flask運用Xterm實現(xiàn)交互終端的示例詳解

    Xterm是一個基于X Window System的終端仿真器(Terminal Emulator),Xterm最初由MIT開發(fā),它允許用戶在X Window環(huán)境下運行文本終端程序,本文給大家介紹了Flask運用Xterm實現(xiàn)交互終端的示例詳解,文中有詳細的代碼講解,需要的朋友可以參考下
    2023-11-11
  • Django跨域請求CSRF的方法示例

    Django跨域請求CSRF的方法示例

    這篇文章主要介紹了Django跨域請求CSRF的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • python基于隱馬爾可夫模型實現(xiàn)中文拼音輸入

    python基于隱馬爾可夫模型實現(xiàn)中文拼音輸入

    這篇文章主要介紹了python基于隱馬爾可夫模型實現(xiàn)中文拼音輸入的相關資料,需要的朋友可以參考下
    2016-04-04
  • python圖片剪裁代碼(圖片按四個點坐標剪裁)

    python圖片剪裁代碼(圖片按四個點坐標剪裁)

    這篇文章主要介紹了python圖片剪裁代碼(圖片按四個點坐標剪裁),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-03-03
  • 基于Python實現(xiàn)一個自動關機程序并打包成exe文件

    基于Python實現(xiàn)一個自動關機程序并打包成exe文件

    這篇文章主要介紹了通過Python創(chuàng)建一個可以自動關機的小程序,并打包成exe文件。文中的示例代碼講解詳細,對我們學習Python有一定的幫助,感興趣的同學可以了解一下
    2021-12-12

最新評論