日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Python之多進(jìn)程與多線程的使用

瀏覽:194日期:2022-06-27 11:24:20
進(jìn)程與線程

想象在學(xué)校的一個(gè)機(jī)房,有固定數(shù)量的電腦,老師安排了一個(gè)爬蟲(chóng)任務(wù)讓大家一起完成,每個(gè)學(xué)生使用一臺(tái)電腦爬取部分?jǐn)?shù)據(jù),將數(shù)據(jù)放到一個(gè)公共數(shù)據(jù)庫(kù)。共同資源就像公共數(shù)據(jù)庫(kù),進(jìn)程就像每一個(gè)學(xué)生,每多一個(gè)學(xué)生,就多一個(gè)進(jìn)程來(lái)完成這個(gè)任務(wù),機(jī)房里的電腦數(shù)量就像CPU,所以進(jìn)程數(shù)量是CPU決定的,線程就像學(xué)生用一臺(tái)電腦開(kāi)多個(gè)爬蟲(chóng),爬蟲(chóng)數(shù)量由每臺(tái)電腦的運(yùn)行內(nèi)存決定。一個(gè)CPU可以有多個(gè)進(jìn)程,一個(gè)進(jìn)程有一個(gè)或多個(gè)線程。

多進(jìn)程

1、導(dǎo)包

from multiprocessing import Process

2、寫(xiě)兩個(gè)任務(wù)也就是兩個(gè)函數(shù)

3、創(chuàng)建一個(gè)進(jìn)程進(jìn)程名字 = Process(target=函數(shù)名字,函數(shù)參數(shù)傳字典或元組,是否守護(hù)進(jìn)程)

4、啟動(dòng)進(jìn)程進(jìn)程名字.start()

5、是否開(kāi)啟進(jìn)程守護(hù),一般主進(jìn)程會(huì)等待子進(jìn)程執(zhí)行完畢后再關(guān)閉程序。當(dāng)我們想程序主進(jìn)程跑完,直接銷毀掉未完成的子進(jìn)程,關(guān)閉程序的話,加上一句代碼 :1.創(chuàng)建進(jìn)程的時(shí)候傳參數(shù)daemon=True2.進(jìn)程名字.daemon=True

6、進(jìn)程編號(hào)導(dǎo)包os獲取當(dāng)前進(jìn)程編號(hào)

os.getpid()

獲取當(dāng)前父進(jìn)程的編號(hào)

os.getppid()

代碼示例(未開(kāi)啟進(jìn)程守護(hù))

from multiprocessing import Processimport timeimport os# 一個(gè)寫(xiě)作業(yè)函數(shù)def homeWork(name, count): for i in range(count): # 打印當(dāng)前進(jìn)程編號(hào)os.getpid() print('當(dāng)前進(jìn)程編號(hào):', os.getpid()) # 打印當(dāng)前父進(jìn)程編號(hào)os.getppid() print('當(dāng)前父進(jìn)程編號(hào):', os.getppid()) print(name, '正在寫(xiě)作業(yè)...') time.sleep(0.2)# 一個(gè)打游戲函數(shù)def game(name, count): for i in range(count): # 打印當(dāng)前進(jìn)程編號(hào)os.getpid() print('當(dāng)前進(jìn)程編號(hào):', os.getpid()) # 打印當(dāng)前父進(jìn)程編號(hào)os.getppid() print('當(dāng)前父進(jìn)程編號(hào):', os.getppid()) print(name, '正在打游戲...') time.sleep(0.2)if __name__ == ’__main__’: # 打印當(dāng)前進(jìn)程編號(hào)os.getpid() print('當(dāng)前進(jìn)程編號(hào):', os.getpid()) # 進(jìn)程1寫(xiě)作業(yè) 元組傳參 p1 = Process(target=homeWork, args=('進(jìn)程1', 10)) # 進(jìn)程2打游戲 字典傳參 p2 = Process(target=game, kwargs={'name': '進(jìn)程2', 'count': 10}) # 啟動(dòng)進(jìn)程 p1.start() p2.start() time.sleep(1) print('主進(jìn)程結(jié)束---------------------------------------------')

未開(kāi)啟線程守護(hù)的運(yùn)行結(jié)果:

# 可以看到主進(jìn)程結(jié)束的,其子進(jìn)程還在繼續(xù)當(dāng)前進(jìn)程編號(hào): 14972當(dāng)前進(jìn)程編號(hào): 5732當(dāng)前父進(jìn)程編號(hào): 14972進(jìn)程1 正在寫(xiě)作業(yè)...當(dāng)前進(jìn)程編號(hào): 14752當(dāng)前父進(jìn)程編號(hào): 14972進(jìn)程2 正在打游戲...當(dāng)前進(jìn)程編號(hào): 5732當(dāng)前父進(jìn)程編號(hào): 14972進(jìn)程1 正在寫(xiě)作業(yè)...當(dāng)前進(jìn)程編號(hào): 14752當(dāng)前父進(jìn)程編號(hào): 14972進(jìn)程2 正在打游戲...當(dāng)前進(jìn)程編號(hào): 5732當(dāng)前父進(jìn)程編號(hào): 14972進(jìn)程1 正在寫(xiě)作業(yè)...當(dāng)前進(jìn)程編號(hào): 14752當(dāng)前父進(jìn)程編號(hào): 14972進(jìn)程2 正在打游戲...當(dāng)前進(jìn)程編號(hào): 5732當(dāng)前父進(jìn)程編號(hào): 14972進(jìn)程1 正在寫(xiě)作業(yè)...當(dāng)前進(jìn)程編號(hào): 14752當(dāng)前父進(jìn)程編號(hào): 14972進(jìn)程2 正在打游戲...主進(jìn)程結(jié)束---------------------------------------------當(dāng)前進(jìn)程編號(hào): 5732當(dāng)前父進(jìn)程編號(hào): 14972進(jìn)程1 正在寫(xiě)作業(yè)...當(dāng)前進(jìn)程編號(hào): 14752當(dāng)前父進(jìn)程編號(hào): 14972進(jìn)程2 正在打游戲...當(dāng)前進(jìn)程編號(hào): 5732當(dāng)前父進(jìn)程編號(hào): 14972進(jìn)程1 正在寫(xiě)作業(yè)...當(dāng)前進(jìn)程編號(hào): 14752當(dāng)前父進(jìn)程編號(hào): 14972進(jìn)程2 正在打游戲...當(dāng)前進(jìn)程編號(hào): 5732當(dāng)前父進(jìn)程編號(hào): 14972進(jìn)程1 正在寫(xiě)作業(yè)...當(dāng)前進(jìn)程編號(hào): 14752當(dāng)前父進(jìn)程編號(hào): 14972進(jìn)程2 正在打游戲...當(dāng)前進(jìn)程編號(hào): 5732當(dāng)前父進(jìn)程編號(hào): 14972進(jìn)程1 正在寫(xiě)作業(yè)...當(dāng)前進(jìn)程編號(hào): 14752當(dāng)前父進(jìn)程編號(hào): 14972進(jìn)程2 正在打游戲...當(dāng)前進(jìn)程編號(hào): 5732當(dāng)前父進(jìn)程編號(hào): 14972進(jìn)程1 正在寫(xiě)作業(yè)...當(dāng)前進(jìn)程編號(hào): 14752當(dāng)前父進(jìn)程編號(hào): 14972進(jìn)程2 正在打游戲...當(dāng)前進(jìn)程編號(hào): 5732當(dāng)前父進(jìn)程編號(hào): 14972進(jìn)程1 正在寫(xiě)作業(yè)...當(dāng)前進(jìn)程編號(hào): 14752當(dāng)前父進(jìn)程編號(hào): 14972進(jìn)程2 正在打游戲...

Process finished with exit code 0

代碼示例(開(kāi)啟進(jìn)程守護(hù))

from multiprocessing import Processimport timeimport os# 一個(gè)寫(xiě)作業(yè)函數(shù)def homeWork(name, count): for i in range(count): # 打印當(dāng)前進(jìn)程編號(hào)os.getpid() print('當(dāng)前進(jìn)程編號(hào):', os.getpid()) # 打印當(dāng)前父進(jìn)程編號(hào)os.getppid() print('當(dāng)前父進(jìn)程編號(hào):', os.getppid()) print(name, '正在寫(xiě)作業(yè)...') time.sleep(0.2)# 一個(gè)打游戲函數(shù)def game(name, count): for i in range(count): # 打印當(dāng)前進(jìn)程編號(hào)os.getpid() print('當(dāng)前進(jìn)程編號(hào):', os.getpid()) # 打印當(dāng)前父進(jìn)程編號(hào)os.getppid() print('當(dāng)前父進(jìn)程編號(hào):', os.getppid()) print(name, '正在打游戲...') time.sleep(0.2)if __name__ == ’__main__’: # 打印當(dāng)前進(jìn)程編號(hào)os.getpid() print('當(dāng)前進(jìn)程編號(hào):', os.getpid()) # 進(jìn)程1寫(xiě)作業(yè) 元組傳參 第一種方法啟動(dòng)進(jìn)程守護(hù) p1 = Process(target=homeWork, args=('進(jìn)程1', 10), daemon=True) # 進(jìn)程2打游戲 字典傳參 p2 = Process(target=game, kwargs={'name': '進(jìn)程2', 'count': 10}) # 第二種 p2.daemon = True # 啟動(dòng)進(jìn)程 p1.start() p2.start() time.sleep(1) print('主進(jìn)程---------------------------------------------')

開(kāi)啟進(jìn)程守護(hù)的運(yùn)行結(jié)果

當(dāng)前進(jìn)程編號(hào): 372當(dāng)前進(jìn)程編號(hào): 10116當(dāng)前進(jìn)程編號(hào): 9860當(dāng)前父進(jìn)程編號(hào): 372進(jìn)程1 正在寫(xiě)作業(yè)...當(dāng)前父進(jìn)程編號(hào): 372進(jìn)程2 正在打游戲...當(dāng)前進(jìn)程編號(hào): 9860當(dāng)前進(jìn)程編號(hào): 10116當(dāng)前父進(jìn)程編號(hào): 372進(jìn)程2 正在打游戲...當(dāng)前父進(jìn)程編號(hào): 372進(jìn)程1 正在寫(xiě)作業(yè)...當(dāng)前進(jìn)程編號(hào): 9860當(dāng)前進(jìn)程編號(hào): 10116當(dāng)前父進(jìn)程編號(hào): 372進(jìn)程1 正在寫(xiě)作業(yè)...當(dāng)前父進(jìn)程編號(hào): 372進(jìn)程2 正在打游戲...當(dāng)前進(jìn)程編號(hào): 9860當(dāng)前進(jìn)程編號(hào): 10116當(dāng)前父進(jìn)程編號(hào): 372進(jìn)程1 正在寫(xiě)作業(yè)...當(dāng)前父進(jìn)程編號(hào): 372進(jìn)程2 正在打游戲...主進(jìn)程結(jié)束---------------------------------------------

Process finished with exit code 0

多線程

1、導(dǎo)包

import threading

2、寫(xiě)兩個(gè)任務(wù)也就是兩個(gè)函數(shù)

3、創(chuàng)建一個(gè)線程線程名字 = threading.Thread(target=函數(shù)名字,函數(shù)參數(shù)傳字典或元組,是否守護(hù)進(jìn)程)

4、啟動(dòng)線程線程名字.start()

5、是否開(kāi)啟線程守護(hù),一般當(dāng)前程序會(huì)等待子線程執(zhí)行完畢后再關(guān)閉程序。當(dāng)我們想程序跑完,銷毀掉未完成的子線程,直接關(guān)閉程序的話,加上一句代碼 :1.創(chuàng)建線程的時(shí)候傳參數(shù)daemon=True2.線程名字.daemon=True

6、線程編號(hào)獲取當(dāng)前線程編號(hào)

threading.current_thread()

代碼示例(未開(kāi)啟進(jìn)程守護(hù))

import threadingimport time# 一個(gè)寫(xiě)作業(yè)函數(shù)def homeWork(name, count): for i in range(count): # 打印當(dāng)前線程 print(threading.current_thread()) print(name, '正在寫(xiě)作業(yè)...') time.sleep(0.2)# 一個(gè)打游戲函數(shù)def game(name, count): for i in range(count): # 打印當(dāng)前線程 print(threading.current_thread()) print(name, '正在打游戲...') time.sleep(0.2)if __name__ == ’__main__’: # 線程1寫(xiě)作業(yè) 元組傳參 t1 = threading.Thread(target=homeWork, args=('進(jìn)程1', 10)) # 線程2打游戲 字典傳參 t2 = threading.Thread(target=game, kwargs={'name': '進(jìn)程2', 'count': 10}) # 啟動(dòng)進(jìn)程 t1.start() t2.start() time.sleep(1) print('主進(jìn)程結(jié)束###################################################################################')

未開(kāi)啟線程守護(hù)的運(yùn)行結(jié)果

# 可以看到主進(jìn)程結(jié)束的,其線程還在繼續(xù)<Thread(Thread-1, started 3364)>進(jìn)程1 正在寫(xiě)作業(yè)...<Thread(Thread-2, started 9100)>進(jìn)程2 正在打游戲...<Thread(Thread-2, started 9100)>進(jìn)程2 正在打游戲...<Thread(Thread-1, started 3364)>進(jìn)程1 正在寫(xiě)作業(yè)...<Thread(Thread-1, started 3364)>進(jìn)程1 正在寫(xiě)作業(yè)...<Thread(Thread-2, started 9100)>進(jìn)程2 正在打游戲...<Thread(Thread-2, started 9100)>進(jìn)程2 正在打游戲...<Thread(Thread-1, started 3364)>進(jìn)程1 正在寫(xiě)作業(yè)...<Thread(Thread-1, started 3364)>進(jìn)程1 正在寫(xiě)作業(yè)...<Thread(Thread-2, started 9100)>進(jìn)程2 正在打游戲...主進(jìn)程結(jié)束###################################################################################<Thread(Thread-2, started 9100)>進(jìn)程2 正在打游戲...<Thread(Thread-1, started 3364)>進(jìn)程1 正在寫(xiě)作業(yè)...<Thread(Thread-1, started 3364)><Thread(Thread-2, started 9100)>進(jìn)程2 正在打游戲...進(jìn)程1 正在寫(xiě)作業(yè)...<Thread(Thread-1, started 3364)>進(jìn)程1 正在寫(xiě)作業(yè)...<Thread(Thread-2, started 9100)>進(jìn)程2 正在打游戲...<Thread(Thread-2, started 9100)><Thread(Thread-1, started 3364)>進(jìn)程1 進(jìn)程2正在寫(xiě)作業(yè)... 正在打游戲...<Thread(Thread-2, started 9100)><Thread(Thread-1, started 3364)>

進(jìn)程2 進(jìn)程1 正在打游戲...正在寫(xiě)作業(yè)...

Process finished with exit code 0

代碼示例(開(kāi)啟線程守護(hù))

import threadingimport time# 一個(gè)寫(xiě)作業(yè)函數(shù)def homeWork(name, count): for i in range(count): # 打印當(dāng)前線程 print(threading.current_thread()) print(name, '正在寫(xiě)作業(yè)...') time.sleep(0.2)# 一個(gè)打游戲函數(shù)def game(name, count): for i in range(count): # 打印當(dāng)前線程 print(threading.current_thread()) print(name, '正在打游戲...') time.sleep(0.2)if __name__ == ’__main__’: # 線程1寫(xiě)作業(yè) 元組傳參 t1 = threading.Thread(target=homeWork, args=('進(jìn)程1', 10), daemon=True) # 線程2打游戲 字典傳參 t2 = threading.Thread(target=game, kwargs={'name': '進(jìn)程2', 'count': 10}) t2.daemon = True # 啟動(dòng)進(jìn)程 t1.start() t2.start() time.sleep(1) print('主進(jìn)程結(jié)束###################################################################################')

開(kāi)啟線程守護(hù)的運(yùn)行結(jié)果

<Thread(Thread-1, started daemon 15480)>進(jìn)程1 正在寫(xiě)作業(yè)...<Thread(Thread-2, started daemon 13700)>進(jìn)程2 正在打游戲...<Thread(Thread-2, started daemon 13700)>進(jìn)程2 正在打游戲...<Thread(Thread-1, started daemon 15480)>進(jìn)程1 正在寫(xiě)作業(yè)...<Thread(Thread-1, started daemon 15480)><Thread(Thread-2, started daemon 13700)>進(jìn)程1 進(jìn)程2 正在寫(xiě)作業(yè)...正在打游戲...

<Thread(Thread-2, started daemon 13700)><Thread(Thread-1, started daemon 15480)>

進(jìn)程1進(jìn)程2 正在寫(xiě)作業(yè)... 正在打游戲...

<Thread(Thread-1, started daemon 15480)>進(jìn)程1 正在寫(xiě)作業(yè)...<Thread(Thread-2, started daemon 13700)>進(jìn)程2 正在打游戲...主進(jìn)程結(jié)束###################################################################################

Process finished with exit code 0

到此這篇關(guān)于Python之多進(jìn)程與多線程的使用的文章就介紹到這了,更多相關(guān)Python 多進(jìn)程與多線程內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Python 編程
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
bbw在线视频| 中文在线一区| 91九色综合| 欧美日韩1区| 日本一区免费网站| 亚洲精品在线二区| 亚洲精品在线二区| 日韩精品视频在线看| 亚洲综合电影一区二区三区| 狠狠久久婷婷| 免费在线欧美视频| 中文字幕av一区二区三区人 | 久久久精品区| 福利一区在线| 久久精品主播| 91久久久久| 蜜芽一区二区三区| 日韩精品导航| 欧美a级一区二区| av资源中文在线天堂| 日韩欧美二区| 亚州av乱码久久精品蜜桃| 久久在线电影| 久久女人天堂| 99国产精品视频免费观看一公开 | 日韩不卡免费视频| 国产精品综合| 成人亚洲精品| 欧美一区二区性| 免费在线观看视频一区| 日本不卡高清| 国产精品久久久久久av公交车| 麻豆高清免费国产一区| 麻豆精品一区二区综合av| 欧美激情国产在线| 不卡在线一区| 亚洲aa在线| 国产激情一区| 少妇久久久久| 综合视频一区| 精品国产一区二区三区2021| www.51av欧美视频| 欧美日韩中文字幕一区二区三区| 视频一区视频二区在线观看| 国产欧美二区| 日韩中文影院| 亚洲天堂日韩在线| 麻豆成人av在线| 国产99久久| 91成人在线| 亚洲韩日在线| 午夜欧美理论片| 日本天堂一区| 中文字幕成在线观看| 亚洲大全视频| 99国产精品视频免费观看一公开 | 色婷婷成人网| 国产伦理一区| 久久久蜜桃一区二区人| 视频一区日韩精品| 欧美丰满日韩| 亚洲综合中文| 日韩精品dvd| 亚洲精品大片| 亚洲成a人片| 日本不卡视频一二三区| 日韩精品第一区| 日韩动漫一区| 91久久久精品国产| 老司机精品视频在线播放| 亚洲免费中文| 国产劲爆久久| 免费日本视频一区| 亚洲天堂免费电影| 国产亚洲久久| 99国产精品| 国产在线观看www| 日韩精品中文字幕吗一区二区| 日韩免费高清| 国产欧美一级| 午夜在线一区| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 国产一区丝袜| 综合亚洲色图| 久久国产中文字幕| 精品国产亚洲日本| 日本午夜精品一区二区三区电影| 欧美精品一二| 日韩在线观看| 欧美激情视频一区二区三区免费 | 国产亚洲欧美日韩精品一区二区三区| 蜜臀av免费一区二区三区| 久久久久97| 日本麻豆一区二区三区视频| 国产在线欧美| 黄色在线观看www| 国产精品啊v在线| 亚洲aa在线| 亚洲欧美激情诱惑| 亚洲午夜久久久久久尤物| 国产一区二区三区日韩精品| 亚洲久久一区| 一本一本久久| 欧美日中文字幕| 精品一区二区三区亚洲| 日韩va欧美va亚洲va久久| 日韩一区二区免费看| 一区二区三区四区在线看| 久久久久久婷| 精品网站999| 国内在线观看一区二区三区 | 国产精品久久久久9999高清| 日本综合精品一区| 日本中文字幕不卡| 日韩视频一二区| 久久午夜视频| 日韩影院免费视频| 亚洲乱亚洲高清| 亚洲人亚洲人色久| 日韩午夜视频在线| 日韩精品久久久久久久软件91| 亚洲一区二区三区四区电影 | 红杏一区二区三区| 亚洲精品国产偷自在线观看| 爽好久久久欧美精品| 成人久久一区| 国产精品高清一区二区| 在线观看一区| 日韩成人精品一区二区三区 | 欧美综合二区| 免费视频亚洲| 韩国精品主播一区二区在线观看| 麻豆精品视频在线观看| 国产探花在线精品| 日韩精彩视频在线观看| 日韩午夜免费| 视频一区二区中文字幕| 亚洲手机视频| 日本在线高清| 国产videos久久| 九九九精品视频| 日韩超碰人人爽人人做人人添| 88久久精品| 欧美亚洲国产日韩| 亚洲三级精品| 亚洲麻豆一区| 少妇精品在线| 久久99久久人婷婷精品综合| 国产亚洲第一伦理第一区| 欧美日一区二区三区在线观看国产免 | 国语对白精品一区二区| 久久99蜜桃| 久久99久久久精品欧美| 国产精品白丝久久av网站| 国产精品一区二区美女视频免费看 | 欧美少妇精品| 精品国产18久久久久久二百| 国产探花一区| 国产亚洲精品精品国产亚洲综合| 蜜桃久久精品一区二区| 欧美亚洲网站| 国产极品模特精品一二 | 日韩亚洲精品在线观看| 性欧美xxxx免费岛国不卡电影| 午夜精品成人av| 日韩精品看片| 欧美精品一区二区三区精品| 亚洲免费观看| 喷白浆一区二区| 中文字幕成人| 涩涩涩久久久成人精品| 日本午夜精品视频在线观看| 国产美女久久| 久久69成人| 国产精品久久久久av电视剧| 在线综合视频| 亚洲精品一二| 日韩1区2区日韩1区2区| 国产精品伊人| 蜜桃视频在线网站| 国产色综合网| 欧美日韩伊人| 国产不卡人人| 亚洲中字黄色| 国产日韩欧美三区| 中文在线资源| 欧美1级日本1级| 亚洲1区在线观看| 免费一级欧美片在线观看网站 | 久久精品999| 91一区二区| 蜜臀a∨国产成人精品| 久久久久黄色| 精品一区三区| 欧美专区一区| 日本欧美不卡| 亚洲专区在线| 高清不卡亚洲| 日韩视频二区| 国产精品二区影院|