首頁  >  文章  >  後端開發  >  python中多執行緒與多進程的區別

python中多執行緒與多進程的區別

清浅
清浅原創
2019-04-08 11:20:275447瀏覽

Python中多行程與多執行緒的差別有:執行緒需要在行程中執行,一個行程可包含多個執行緒;行程可共享同一個位址空間而行程共享物理位址,執行緒建立簡單,行程需要對父進程克隆等等

今天將要分享的是Python中多進程與多線程的相關知識及區別,接下來將在文章中具體介紹,具有一定的參考價值,希望對大家有所幫助

python中多執行緒與多進程的區別

【推薦課程:Python教學

執行緒的概念:

執行緒是作業系統中進行運算調度的最小單位。它被包含在進程之中,是進程中的實際運作單位。一條線程指的是進程中一個單一順序的控制流,一個進程可以有多個線程,每個線程可以同時執行不同的任務。一個執行緒可以看作一個cpu執行時所需要的一串指令

多執行緒 

在Python的標準函式庫中提供了兩個模組:_thread與threading ,_thread是低階模組不支援守護線程,當主線程退出時,所有子線程都會被強行退出。而threading是高級模組,用於對_thread進行了封裝支援守護線程。在大多數情況下我們只需要使用threading這個高級模組即可。

python中多執行緒與多進程的區別

進程的概念:

程式指的是一個程式在給定資料集合上的一次執行過程,是系統進行資源分配和運行呼叫的獨立單位。也就是每一個應用程式都有一個自己的進程。行程在啟動時都會先產生一個線程,這個線程被稱為主線程,然後再有主線程創建其他子線程

多進程:

多進程是multiprocessing模組提供遠端與本地的並發,在一個multiprocessing庫的使用場景下,所有的子進程都是由一個父進程啟動來的,這個父進程成為madter進程,它會管理一系列的物件狀態,一旦這個行程退出,子行程很可能處於一個不穩定的狀態,所以這個父行程盡量要少做事來保持其穩定性

python中多執行緒與多進程的區別

執行緒與行程的區別

(1)執行緒必須在某個行程中執行。一個行程可包含多個線程,且只有一個主線程。

(2)多執行緒共享同一個位址空間、開啟的檔案以及其他資源。而多進程共享實體記憶體、磁碟、印表機以及其他資源。

(3)執行緒幾乎不佔資源,系統開銷少,切換速度快,而且同一個行程中的多個執行緒可以實現資料共享,而行程之間是不可共享的

#(4)新執行緒的建立很簡單而新行程的建立需要對父行程進行複製

(5)一個執行緒可以控制和操作同一行程裡的其他執行緒;但是行程只能操作子行程

總結:以上就是這篇文章的全部內容了,希望對大家有幫助。

以上是python中多執行緒與多進程的區別的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn