您好,登錄后才能下訂單哦!
本文實(shí)例講述了python進(jìn)程的狀態(tài)、創(chuàng)建及使用方法。分享給大家供大家參考,具體如下:
進(jìn)程以及狀態(tài)
1. 進(jìn)程
程序:例如xxx.py這是程序,是一個(gè)靜態(tài)的
進(jìn)程:一個(gè)程序運(yùn)行起來后,代碼+用到的資源 稱之為進(jìn)程,它是操作系統(tǒng)分配資源的基本單元。
不僅可以通過線程完成多任務(wù),進(jìn)程也是可以的
2. 進(jìn)程的狀態(tài)
工作中,任務(wù)數(shù)往往大于cpu的核數(shù),即一定有一些任務(wù)正在執(zhí)行,而另外一些任務(wù)在等待cpu進(jìn)行執(zhí)行,因此導(dǎo)致了有了不同的狀態(tài)
進(jìn)程的創(chuàng)建-multiprocessing
multiprocessing模塊就是跨平臺(tái)版本的多進(jìn)程模塊,提供了一個(gè)Process類來代表一個(gè)進(jìn)程對象,這個(gè)對象可以理解為是一個(gè)獨(dú)立的進(jìn)程,可以執(zhí)行另外的事情
1. 2個(gè)while循環(huán)一起執(zhí)行
# -*- coding:utf-8 -*- from multiprocessing import Process import time def run_proc(): """子進(jìn)程要執(zhí)行的代碼""" while True: print("----2----") time.sleep(1) if __name__=='__main__': p = Process(target=run_proc) p.start() while True: print("----1----") time.sleep(1)
說明
2. 進(jìn)程pid
# -*- coding:utf-8 -*- from multiprocessing import Process import os import time def run_proc(): """子進(jìn)程要執(zhí)行的代碼""" print('子進(jìn)程運(yùn)行中,pid=%d...' % os.getpid()) # os.getpid獲取當(dāng)前進(jìn)程的進(jìn)程號(hào) print('子進(jìn)程將要結(jié)束...') if __name__ == '__main__': print('父進(jìn)程pid: %d' % os.getpid()) # os.getpid獲取當(dāng)前進(jìn)程的進(jìn)程號(hào) p = Process(target=run_proc) p.start()
3. Process語法結(jié)構(gòu)如下:
Process([group [, target [, name [, args [, kwargs]]]]])
Process創(chuàng)建的實(shí)例對象的常用方法:
Process創(chuàng)建的實(shí)例對象的常用屬性:
4. 給子進(jìn)程指定的函數(shù)傳遞參數(shù)
# -*- coding:utf-8 -*- from multiprocessing import Process import os from time import sleep def run_proc(name, age, **kwargs): for i in range(10): print('子進(jìn)程運(yùn)行中,name= %s,age=%d ,pid=%d...' % (name, age, os.getpid())) print(kwargs) sleep(0.2) if __name__=='__main__': p = Process(target=run_proc, args=('test',18), kwargs={"m":20}) p.start() sleep(1) # 1秒中之后,立即結(jié)束子進(jìn)程 p.terminate() p.join()
運(yùn)行結(jié)果:
子進(jìn)程運(yùn)行中,name= test,age=18 ,pid=45097...
{'m': 20}
子進(jìn)程運(yùn)行中,name= test,age=18 ,pid=45097...
{'m': 20}
子進(jìn)程運(yùn)行中,name= test,age=18 ,pid=45097...
{'m': 20}
子進(jìn)程運(yùn)行中,name= test,age=18 ,pid=45097...
{'m': 20}
子進(jìn)程運(yùn)行中,name= test,age=18 ,pid=45097...
{'m': 20}
5. 進(jìn)程間不同享全局變量
# -*- coding:utf-8 -*- from multiprocessing import Process import os import time nums = [11, 22] def work1(): """子進(jìn)程要執(zhí)行的代碼""" print("in process1 pid=%d ,nums=%s" % (os.getpid(), nums)) for i in range(3): nums.append(i) time.sleep(1) print("in process1 pid=%d ,nums=%s" % (os.getpid(), nums)) def work2(): """子進(jìn)程要執(zhí)行的代碼""" print("in process2 pid=%d ,nums=%s" % (os.getpid(), nums)) if __name__ == '__main__': p1 = Process(target=work1) p1.start() p1.join() p2 = Process(target=work2) p2.start()
運(yùn)行結(jié)果:
in process1 pid=11349 ,nums=[11, 22]
in process1 pid=11349 ,nums=[11, 22, 0]
in process1 pid=11349 ,nums=[11, 22, 0, 1]
in process1 pid=11349 ,nums=[11, 22, 0, 1, 2]
in process2 pid=11350 ,nums=[11, 22]
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python進(jìn)程與線程操作技巧總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進(jìn)階經(jīng)典教程》、《Python+MySQL數(shù)據(jù)庫程序設(shè)計(jì)入門教程》及《Python常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家Python程序設(shè)計(jì)有所幫助。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。