python進(jìn)程的狀態(tài)、創(chuàng)建及使用方法詳解
本文實例講述了python進(jìn)程的狀態(tài)、創(chuàng)建及使用方法。分享給大家供大家參考,具體如下:
進(jìn)程以及狀態(tài)
1. 進(jìn)程
程序:例如xxx.py這是程序,是一個靜態(tài)的
進(jì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)
- 就緒態(tài):運行的條件都已經(jīng)慢去,正在等在cpu執(zhí)行
- 執(zhí)行態(tài):cpu正在執(zhí)行其功能
- 等待態(tài):等待某些條件滿足,例如一個程序sleep了,此時就處于等待態(tài)
進(jìn)程的創(chuàng)建-multiprocessing
multiprocessing模塊就是跨平臺版本的多進(jìn)程模塊,提供了一個Process類來代表一個進(jìn)程對象,這個對象可以理解為是一個獨立的進(jìn)程,可以執(zhí)行另外的事情
1. 2個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)
說明
- 創(chuàng)建子進(jìn)程時,只需要傳入一個執(zhí)行函數(shù)和函數(shù)的參數(shù),創(chuàng)建一個Process實例,用start()方法啟動
2. 進(jìn)程pid
# -*- coding:utf-8 -*-
from multiprocessing import Process
import os
import time
def run_proc():
"""子進(jìn)程要執(zhí)行的代碼"""
print('子進(jìn)程運行中,pid=%d...' % os.getpid()) # os.getpid獲取當(dāng)前進(jìn)程的進(jìn)程號
print('子進(jìn)程將要結(jié)束...')
if __name__ == '__main__':
print('父進(jìn)程pid: %d' % os.getpid()) # os.getpid獲取當(dāng)前進(jìn)程的進(jìn)程號
p = Process(target=run_proc)
p.start()
3. Process語法結(jié)構(gòu)如下:
Process([group [, target [, name [, args [, kwargs]]]]])
- target:如果傳遞了函數(shù)的引用,可以任務(wù)這個子進(jìn)程就執(zhí)行這里的代碼
- args:給target指定的函數(shù)傳遞的參數(shù),以元組的方式傳遞
- kwargs:給target指定的函數(shù)傳遞命名參數(shù)
- name:給進(jìn)程設(shè)定一個名字,可以不設(shè)定
- group:指定進(jìn)程組,大多數(shù)情況下用不到
Process創(chuàng)建的實例對象的常用方法:
- start():啟動子進(jìn)程實例(創(chuàng)建子進(jìn)程)
- is_alive():判斷進(jìn)程子進(jìn)程是否還在活著
- join([timeout]):是否等待子進(jìn)程執(zhí)行結(jié)束,或等待多少秒
- terminate():不管任務(wù)是否完成,立即終止子進(jìn)程
Process創(chuàng)建的實例對象的常用屬性:
- name:當(dāng)前進(jìn)程的別名,默認(rèn)為Process-N,N為從1開始遞增的整數(shù)
- pid:當(dāng)前進(jìn)程的pid(進(jìn)程號)
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)程運行中,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()
運行結(jié)果:
子進(jìn)程運行中,name= test,age=18 ,pid=45097...
{'m': 20}
子進(jìn)程運行中,name= test,age=18 ,pid=45097...
{'m': 20}
子進(jìn)程運行中,name= test,age=18 ,pid=45097...
{'m': 20}
子進(jìn)程運行中,name= test,age=18 ,pid=45097...
{'m': 20}
子進(jì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()
運行結(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è)計入門教程》及《Python常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家Python程序設(shè)計有所幫助。
- python監(jiān)控進(jìn)程狀態(tài),記錄重啟時間及進(jìn)程號的實例
- python監(jiān)控nginx端口和進(jìn)程狀態(tài)
- 小結(jié)Python用fork來創(chuàng)建子進(jìn)程注意事項
- Python使用multiprocessing創(chuàng)建進(jìn)程的方法
- Python 創(chuàng)建子進(jìn)程模塊subprocess詳解
- python在windows下創(chuàng)建隱藏窗口子進(jìn)程的方法
- python基于multiprocessing的多進(jìn)程創(chuàng)建方法
- python創(chuàng)建進(jìn)程fork用法
- 對Python中創(chuàng)建進(jìn)程的兩種方式以及進(jìn)程池詳解
- python 進(jìn)程的幾種創(chuàng)建方式詳解
- 淺析Python中的多進(jìn)程與多線程的使用
- Python中使用多進(jìn)程來實現(xiàn)并行處理的方法小結(jié)
相關(guān)文章
Django項目中包含多個應(yīng)用時對url的配置方法
今天小編就為大家分享一篇Django項目中包含多個應(yīng)用時對url的配置方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-05-05
使用PowerShell實現(xiàn)批量修改或替換文件名
這篇文章主要為大家介紹了基于PowerShell語言,對文件夾中全部文件的名稱加以批量替換、修改的方法,文中的示例代碼講解詳細(xì),感興趣的可以了解一下2023-04-04
淺談keras中的目標(biāo)函數(shù)和優(yōu)化函數(shù)MSE用法
這篇文章主要介紹了淺談keras中的目標(biāo)函數(shù)和優(yōu)化函數(shù)MSE用法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06
Python 創(chuàng)建守護(hù)進(jìn)程的示例
這篇文章主要介紹了Python 創(chuàng)建守護(hù)進(jìn)程的示例,幫助大家更好的理解和使用python,感興趣的朋友可以了解下2020-09-09

