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

python進(jìn)程的狀態(tài)、創(chuàng)建及使用方法詳解

 更新時間:2019年12月06日 09:40:45   作者:xlengji  
這篇文章主要介紹了python進(jìn)程的狀態(tài)、創(chuàng)建及使用方法,結(jié)合實例形式詳細(xì)分析了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è)計有所幫助。

相關(guān)文章

  • Django中的AutoField字段使用

    Django中的AutoField字段使用

    這篇文章主要介紹了Django中的AutoField字段使用,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05
  • python如何將多個PDF進(jìn)行合并

    python如何將多個PDF進(jìn)行合并

    這篇文章主要為大家詳細(xì)介紹了python如何將多個PDF進(jìn)行合并,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • Python 刪除整個文本中的空格,并實現(xiàn)按行顯示

    Python 刪除整個文本中的空格,并實現(xiàn)按行顯示

    今天小編就為大家分享一篇Python 刪除整個文本中的空格,并實現(xiàn)按行顯示,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07
  • python中的tcp示例詳解

    python中的tcp示例詳解

    這篇文章主要給大家介紹了關(guān)于python中tcp協(xié)議的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-12-12
  • 詳解利用裝飾器擴展Python計時器

    詳解利用裝飾器擴展Python計時器

    在本文中,云朵君將和大家一起了解裝飾器的工作原理,如何將我們之前定義的定時器類?Timer?擴展為裝飾器,以及如何簡化計時功能,感興趣的可以了解一下
    2022-06-06
  • python函數(shù)裝飾器構(gòu)造和參數(shù)傳遞

    python函數(shù)裝飾器構(gòu)造和參數(shù)傳遞

    這篇文章主要介紹了python函數(shù)裝飾器構(gòu)造和參數(shù)傳遞,下面通過一個小案例來簡單的理解什么是裝飾器,需要的小伙伴可以參考一下
    2022-03-03
  • Python中SQLAlchemy庫的使用方法分析

    Python中SQLAlchemy庫的使用方法分析

    SQLAlchemy 是Python SQL工具包和對象關(guān)系映射器(ORM),允許Python開發(fā)者在應(yīng)用程序中使用SQL來交互,而無需處理數(shù)據(jù)庫的具體細(xì)節(jié),本文給大家詳細(xì)分析了Python中SQLAlchemy庫的使用方法,需要的朋友可以參考下
    2024-08-08
  • Python機器學(xué)習(xí)NLP自然語言處理基本操作精確分詞

    Python機器學(xué)習(xí)NLP自然語言處理基本操作精確分詞

    本文是Python機器學(xué)習(xí)NLP自然語言處理系列文章,帶大家開啟一段學(xué)習(xí)自然語言處理 (NLP) 的旅程. 本文主要學(xué)習(xí)NLP自然語言處理基本操作之如何精確分詞
    2021-09-09
  • python實現(xiàn)輸入三角形邊長自動作圖求面積案例

    python實現(xiàn)輸入三角形邊長自動作圖求面積案例

    這篇文章主要介紹了python實現(xiàn)輸入三角形邊長自動作圖求面積案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-04-04
  • 使用python 獲取進(jìn)程pid號的方法

    使用python 獲取進(jìn)程pid號的方法

    這篇文章主要介紹了使用python 獲取進(jìn)程pid號的方法,需要的朋友可以參考下
    2014-03-03

最新評論