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

python多進程基礎(chǔ)詳解

 更新時間:2021年10月09日 14:44:23   作者:七層漢堡王  
這篇文章主要介紹了Python多進程基礎(chǔ),結(jié)合實例形式分析了Python多進程原理、開啟使用進程、進程隊列、進程池等相關(guān)概念與使用方法,需要的朋友可以參考下

進程

什么是進程
進程指的是一個程序的運行過程,或者說一個正在執(zhí)行的程序
所以說進程一種虛擬的概念,該虛擬概念起源操作系統(tǒng)

一個CPU 同一時刻只能執(zhí)行一件事

開啟一個進程

from  multiprocessing import Process
import time
def task(name):
    print('%s is running'%name)
    time.sleep(3)
    print('%s is done'%name)
# 開啟子進程的操作必須放到
# if __name__ == '__main__'的子代碼中
# 子進程不會再次加載
if __name__ == '__main__':
    p=Process(target=task,args=('小王',))
    # p=Process(target=task,kwargs={'name':'小王'})
    # print(p)
    p.start()
    # 主進程只是向操作系統(tǒng)發(fā)送了一個開啟子進程的信號
    # p.start()
    # 1.操作系統(tǒng)先申請內(nèi)存空間
    # 2.把主進程的數(shù)據(jù)拷貝到子進程里面
    # 3.調(diào)用cup才能運行里面的代碼
    # 創(chuàng)造進程的開銷大
    print('主')

在這里插入圖片描述

JOIN方法

當(dāng)前進程jion別的進程。當(dāng)前進程就會等到別的進程執(zhí)行完畢了才會繼續(xù)開始往下執(zhí)行

在這里插入圖片描述

from multiprocessing import Process
import time

def task(name, n):
    print('%s is running' % name)
    time.sleep(n)
    print('%s is done' % name)

if __name__ == '__main__':
    start = time.time()
    p_l = []
    for i in range(1, 4):
        p = Process(target=task, args=('小王%s' % i, i))
        p_l.append(p)
        p.start()
    # 主進程等待子進程
    for p in p_l:
        p.join()
    print('主', (time.time() - start))

進程之間空間隔離

from multiprocessing import  Process
# 這個n是主進程里面的值
n = 100
def task():
    global n
    # 改的是子進程里面的全局變量
    # 主進程里面沒有改
    n = 0
if __name__ == '__main__':
    p=Process(target=task)
    p.start()
    p.join()
    print(n)

在這里插入圖片描述

進程的常用方法

current_process 查看pid(進程id)

# 1. 進程pid:每一個進程在操作系統(tǒng)內(nèi)都有一個唯一的id號,稱之為pid
from multiprocessing import Process, current_process
import time

def task():
    print('%s is running' % current_process().pid)
    time.sleep(3)
    print('%s is done' % current_process().pid)

# 開啟子進程的操作必須放到
# if __name__ == '__main__'的子代碼中
# 子進程不會再次加載
if __name__ == '__main__':
    p = Process(target=task)
    p.start()
    print('主', current_process().pid)

在這里插入圖片描述

os.getpid() 查看進程id

# os模塊也可以
from multiprocessing import Process, current_process
import time, os

def task():
    print('%s is running 爹是%s' % (os.getpid(), os.getppid()))
    time.sleep(3)
    print('%s is done爹是%s' % (os.getpid(), os.getppid()))

# 開啟子進程的操作必須放到
# if __name__ == '__main__'的子代碼中
# 子進程不會再次加載
if __name__ == '__main__':
    p = Process(target=task)
    p.start()
    # 誰把主進程創(chuàng)造出來的
    #   用pycharm就是pycharm創(chuàng)造的
    print('主%s爹是%s' % (os.getpid(), os.getppid()))

在這里插入圖片描述

進程其他方法和屬性

from multiprocessing import Process,current_process
import time,os
def task():
    print('%s is running 爹是%s'%(os.getpid(),os.getppid()))
    time.sleep(30)
    print('%s is done爹是%s'%(os.getpid(),os.getppid()))
# 開啟子進程的操作必須放到
# if __name__ == '__main__'的子代碼中
# 子進程不會再次加載
if __name__ == '__main__':
    p=Process(target=task)
    p.start()
    # 誰把主進程創(chuàng)造出來的
    # 用pycharm就是pycharm創(chuàng)造的
    # 進程的名字
    print(p.name)
    # 殺死子進程
    p.terminate()
    # 需要時間
    time.sleep(0.1)
    #  判斷子進程是否存活
    print(p.is_alive())
    print('主%s爹是%s'%(os.getpid(),os.getppid()))

在這里插入圖片描述

守護進程

本質(zhì)就是一個"子進程",該"子進程"的生命周期<=被守護進程的生命周期
當(dāng)被守護的進程執(zhí)行完了。它也會被殺死

# 主進程運行完了,子進程沒有存在的意義
# 皇帝和太監(jiān)不是同生,但是是同死
from  multiprocessing import Process
import time
def task(name):
    print('%s活著'%name)
    time.sleep(3)
    print('%s正常死亡'%name)
if __name__ == '__main__':
    p1=Process(target=task,args=('老太監(jiān)',))
    # 聲明子進程為守護進程
    p1.daemon = True
    p1.start()
    time.sleep(1)
    print('皇帝正在死亡')

在這里插入圖片描述

互斥鎖

進程之間內(nèi)存空間互相隔離,怎樣實現(xiàn)共享數(shù)據(jù)
進程之間內(nèi)存數(shù)據(jù)不共享,但是共享同一套文件系統(tǒng),所以訪問同一個文件,是沒有問題的,
而共享帶來的是競爭,競爭帶來的結(jié)果就是錯亂,如何控制,就是加鎖處理

'''
搶票
    查票
    購票
互斥鎖:
    在程序中進行加鎖處理
    必須要釋放鎖下一個鎖才能獲取,所以程序在合適的時候必須要有釋放鎖
所以用文件來處理共享數(shù)據(jù)
    1.速度慢
    2.必須有互斥鎖
'''
import json
import time,random
from multiprocessing import Process,Lock
# 查票
def search(name):
    with open('db.json','rt',encoding='utf-8')as f:
        dic = json.load(f)
    # 模擬查票時間
    time.sleep(1)
    print('%s 查看到余票為 %s'%(name,dic['count']))
# 購票
# 第二個get子進程不會是第一個get子進程修改后count的結(jié)果
# 加互斥鎖,把這一部分并發(fā)變成串行,
# 但是犧牲了效率,保證了數(shù)據(jù)安全
def get(name):
    with open('db.json','rt',encoding='utf-8')as f:
        dic = json.load(f)
    if dic['count']>0:
        dic['count']-=1
        time.sleep(random.randint(1,3))
        with open('db.json', 'wt', encoding='utf-8')as f:
            json.dump(dic,f)
            print('%s 購票成功'%name)
    else:
        print('%s 查看到?jīng)]有票了'%name)
def task(name,mutex):
    # 并發(fā)
    search(name)
    # 串行
    # 加互斥鎖
    mutex.acquire()
    get(name)
    # 釋放互斥鎖
    mutex.release()
# if __name__ == '__main__':
#     for i in range(10):
#         p=Process(target=task,args=('路人%s'%i,))
#         p.start()
#         #  join只能將進程的任務(wù)整體變成串行
#         # 互斥鎖可以局部串行
#         p.join()
#         # 數(shù)據(jù)安全,是指讀的時候無所謂,寫的(改的)時候必須安全
#         # 寫的時候是串行,讀的時候并發(fā)
# 加鎖
if __name__ == '__main__':
    # 主進程加鎖
    mutex=Lock()
    for i in range(10):
        # 鎖傳入子進程
        p=Process(target=task,args=('路人%s'%i,mutex))
        p.start()
        #  join只能將進程的任務(wù)整體變成串行
        # 互斥鎖可以局部串行
        # p.join()
        # 數(shù)據(jù)安全,是指讀的時候無所謂,寫的(改的)時候必須安全
        # 寫的時候是串行,讀的時候并發(fā)

db.json 中只有10張票。如果沒有加鎖。則可能會出現(xiàn)票唄多賣的情況
在這里插入圖片描述

進程間通信(IPC機制)

'''
速度快
鎖問題解決
ipc機制
    進程彼此之間互相隔離,要實現(xiàn)進程間通信(IPC),
    multiprocessing模塊支持兩種形式:隊列和管道,這兩種方式都是使用消息傳遞的
    共享內(nèi)存空間
    隊列=管道+鎖
'''
from  multiprocessing import Queue
# 占用的內(nèi)存,最好小數(shù)據(jù),消息數(shù)據(jù),下載地址
# Queue(限制隊列里面的個數(shù))
# 先進先出
q=Queue(3)
# 添加
q.put('a')
q.put('b')
q.put({'x':2})
print('籃子滿了')
# 隊列滿了,相當(dāng)于鎖了
# q.put({'x':2})
# 提取
print(q.get())
print(q.get())
print(q.get())
# # 隊列為空,等待加入,也會阻塞,相當(dāng)于鎖了
print('隊列為空')
print(q.get())

隊列被取完了 后面的q.get() 會阻塞直到有新的元素。所以程序不會結(jié)束

在這里插入圖片描述

JoinableQueue 來實現(xiàn)生產(chǎn)消費者

JoinableQueue#task_done()方法當(dāng)隊列里面沒有元素會結(jié)束線程

'''
小王和小周每人生產(chǎn)10分包子和土豆絲
小戴和小楊一直吃,當(dāng)隊列里面沒有食物時。終結(jié)進程
'''
import time, random
from multiprocessing import Process, JoinableQueue

def producer(name, food, q):
    for i in range(10):
        res = '%s%s' % (food, i)
        # 模擬生產(chǎn)數(shù)據(jù)的時間
        time.sleep(random.randint(1, 3))
        q.put(res)
        print('廚師%s生成了%s' % (name, res))

def consumer(name, q):
    while True:
        # 訂單都沒了還在等,隊列里面空了
        res = q.get()
        # 模擬處理數(shù)據(jù)的時間
        time.sleep(random.randint(1, 3))
        print('吃貨%s吃了%s' % (name, res))
        # 1每次完成隊列取一次,往q.join() ,取干凈了q.join()運行完
        q.task_done()

# 多個生產(chǎn)者和消費者
if __name__ == '__main__':
    q = JoinableQueue()
    # 生產(chǎn)者
    p1 = Process(target=producer, args=('小王', '包子', q))
    p3 = Process(target=producer, args=('小周', '土豆絲', q))
    # 消費者
    c1 = Process(target=consumer, args=('小戴', q))
    c2 = Process(target=consumer, args=('小楊', q))
    # #3.守護進程的作用: 主進程死了,消費者子進程也跟著死
    #     #把消費者變成守護進程
    c1.daemon = True
    c2.daemon = True
    p1.start()
    p3.start()
    c1.start()
    c2.start()
    p1.join()
    p3.join()
    # 2消費者task_done給q.join()發(fā)信號
    q.join()
    print('主')
    # 生產(chǎn)者運行完?1,2
    # 消費者運行完?1,2

當(dāng)隊列為空時,不會傻傻等待而是結(jié)束進程

在這里插入圖片描述

總結(jié)

本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

  • Python學(xué)習(xí)筆記_數(shù)據(jù)排序方法

    Python學(xué)習(xí)筆記_數(shù)據(jù)排序方法

    Python對數(shù)據(jù)排序有兩種方法:下面我們來簡單分析下
    2014-05-05
  • Python進階之自定義對象實現(xiàn)切片功能

    Python進階之自定義對象實現(xiàn)切片功能

    這篇文章主要介紹了Python進階之自定義對象實現(xiàn)切片功能,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • python比較2個xml內(nèi)容的方法

    python比較2個xml內(nèi)容的方法

    這篇文章主要介紹了python比較2個xml內(nèi)容的方法,涉及Python操作XML文件的相關(guān)技巧,需要的朋友可以參考下
    2015-05-05
  • python中的break、continue、exit()、pass全面解析

    python中的break、continue、exit()、pass全面解析

    下面小編就為大家?guī)硪黄猵ython中的break、continue、exit()、pass全面解析。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • Python使用列表推導(dǎo)式快速生成列表

    Python使用列表推導(dǎo)式快速生成列表

    這篇文章主要介紹了Python使用列表推導(dǎo)式快速生成列表,列表推導(dǎo)式是Python構(gòu)建列表list的一種快捷方式,可以使用簡潔的代碼就創(chuàng)建出一個列表,需要的朋友可以參考下
    2023-07-07
  • Python實現(xiàn)自動回復(fù)討論功能的腳本分享

    Python實現(xiàn)自動回復(fù)討論功能的腳本分享

    這篇文章主要為大家詳細介紹了如何利用Python語言實現(xiàn)自動回復(fù)討論功能的腳本,文中的示例代碼講解詳細,感興趣的小伙伴可以嘗試一下
    2022-10-10
  • Python如何讀取16進制byte數(shù)據(jù)

    Python如何讀取16進制byte數(shù)據(jù)

    這篇文章主要介紹了Python如何讀取16進制byte數(shù)據(jù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • 跟老齊學(xué)Python之有容乃大的list(4)

    跟老齊學(xué)Python之有容乃大的list(4)

    本文是有容乃大的list的第四篇文章,本來只打算寫三篇的,結(jié)果發(fā)現(xiàn)還是有些內(nèi)容沒有介紹清楚,只好再補一篇了。介紹一下對list的操作。
    2014-09-09
  • 淺談python 中類屬性共享的問題

    淺談python 中類屬性共享的問題

    今天小編就為大家分享一篇淺談python 中類屬性共享的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07
  • django創(chuàng)建簡單的頁面響應(yīng)實例教程

    django創(chuàng)建簡單的頁面響應(yīng)實例教程

    這篇文章主要給大家介紹了關(guān)于django如何創(chuàng)建簡單的頁面響應(yīng)的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用django具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09

最新評論