python 多工 程序

2022-05-19 08:00:11 字數 3452 閱讀 9290

什麼是程序?

程式是靜態的,當程式執行起來就叫做程序。

程序是作業系統分配資源的基本單元。

程序、執行緒的區別與優缺點

1. 定義的不同:

程序是系統進行資源分配的最小單位.

執行緒是程序的乙個實體,是cpu進行排程的基本單位。

執行緒自己基本上不擁有系統資源,只擁有一點在執行中必不可少的資源(如程式計數器,一組暫存器和棧),但是它可與同屬乙個程序的其他的執行緒共享程序所擁有的全部資源.

2. 區別:

乙個程式至少有乙個程序,乙個程序至少有乙個執行緒.執行緒的劃分尺度小於程序(資源比程序少),使得多執行緒程式的併發性高。

程序在執行過程中擁有獨立的記憶體單元,而多個執行緒共享記憶體,從而極大地提高了程式的執行效率。

執行緒不能夠獨立執行,必須依存在程序中

3. 優缺點:

執行緒執行開銷小,但不利於資源的管理和保護;而程序正相反。

程序的建立步驟

匯入程序模組

建立乙個程序的例項物件

建立並啟動程序

**實現:

import threading

import time

import multiprocessing

def test1():

while true:

print("1--------")

time.sleep(1)

def test2():

while true:

print("2--------")

time.sleep(1)

def main():

# t1 = threading.thread(target=test1)

# t2 = threading.thread(target=test2)

# t1.start()

# t2.start()

p1 = multiprocessing.process(target=test1)

p2 = multiprocessing.process(target=test2)

p1.start()

p2.start()

if __name__ == "__main__":

main()

通過queue實現程序間通訊

建立乙個佇列

向佇列中新增資料

從佇列中取資料

判斷佇列中是否為空

判斷佇列中是否已滿

**實現如下:

import multiprocessing

"""乙個程序向queue中寫入資料,另外乙個程序從queue中獲取資料,

通過queue完成了 多個需要配合的程序間的資料共享,從而能夠 起到 解耦的作用

"""def download_from_web(q):

data = [11, 22, 33, 44]

# 向佇列中寫入資料

for temp in data:

q.put(temp)

def analysis_data(q):

"""資料處理"""

waitting_analysis_data = list()

# 從佇列中獲取資料

while true:

data = q.get()

if q.empty():

break

# 模擬資料處理

print(waitting_analysis_data)

def main():

# 1. 建立乙個佇列

q = multiprocessing.queue()

# 2. 建立多個程序,將佇列的引用當做實參進行傳遞到裡面

p1 = multiprocessing.process(target=download_from_web, args=(q,))

p2 = multiprocessing.process(target=analysis_data, args=(q,))

p1.start()

p2.start()

if __name__ == "__main__":

main()

注意:

通過程序池建立程序,佇列的使用要用multiprocessing.manager().queue()的方式,否則會報錯。

程序池pool

當需要建立的子程序數量不多時,可以直接利用multiprocessing中的process動態成生多個程序,

但如果是上百甚至上千個目標,手動的去建立程序的工作量巨大,此時就可以用到multiprocessing模組提供的pool方法。

初始化pool時,可以指定乙個最大程序數,當有新的請求提交到pool中時,

如果池還沒有滿,那麼就會建立乙個新的程序用來執行該請求;

但如果池中的程序數已經達到指定的最大值,那麼該請求就會等待,直到池中有程序結束,才會用之前的程序來執行新的任務

程序池的實現步驟

匯入程序池模組

定義程序池,最大程序池最大數

關閉程序池

等待程序池執行完畢

**實現:

from multiprocessing import pool

import os, time, random

def worker(msg):

t_start = time.time()

print("%s開始執行,程序號為%d" % (msg,os.getpid()))

# random.random()隨機生成0~1之間的浮點數

time.sleep(random.random()*2)

t_stop = time.time()

print(msg,"執行完畢,耗時%0.2f" % (t_stop-t_start))

po = pool(3) # 定義乙個程序池,最大程序數3

for i in range(0,10):

# 每次迴圈將會用空閒出來的子程序去呼叫目標

print("----start----")

po.close() # 關閉程序池,關閉後po不再接收新的請求

po.join() # 等待po中所有子程序執行完成,必須放在close語句之後

print("-----end-----")

Python多工之程序

python通過多程序實現多工的幾種方法 只用在類unix linux系統中有效,windows系統中無效 fork函式呼叫一次,返回兩次 在父程序中返回值為子程序id,在子程序中返回值為0 import os ret os.fork if ret 父程序 print 主程序,pid format ...

Python 多工 程序池

高階程式設計技巧 學習筆記 1.1 為什麼要用程序池 當需要建立的子程序數量不多時,可以直接利用multiprocessing中的process動態生成多個程序,但是如果是上百甚至上千個目標,手動的去建立的程序的工作量巨大,此時就可以用到multiprocessing模組提供的pool方法。初始化 ...

python 多工程式設計 程序

程序 想要實現多工可以使用程序來完成,概念 乙個正在執行的程式或者軟體就是乙個程序,它是作業系統進行資源發呢排的基本單位 乙個程式執行後至少有乙個程序,乙個程序預設有乙個執行緒,程序裡面可以建立多個執行緒,執行緒依附在程序裡面的,沒有程序就沒有執行緒。程序的使用 1 匯入程序包 import mul...