學Python的朋友聽說過進程和線程嗎?其實,不僅是Python,學習技術(shù)也涉及進程和線程。后面朋友們還可能接觸到各種線程鎖。那么什么是Python的多進程和多線程呢?以便大家可以有一個基本的了解,那么請看下面:
進程和線程:
進程:在系統(tǒng)中運行的程序,每個進程都是獨立的,運行自己的內(nèi)存,即做自己的工作,互不干擾。
線程:進程的基本執(zhí)行單元,進程的所有任務都在線程中執(zhí)行,啟動程序默認會啟動一個線程,這個線程一般稱為主線程。
從空間上看,同一個進程中的線程共享一個進程的空間,但進程是獨立的空間。從共享的角度來說,同一個進程中的線程共享一個進程的資源,比如內(nèi)存、cpu等。
一個進程崩潰后,不會影響其他進程,但一個線程崩潰后,會導致整個進程崩潰。因此,多進程優(yōu)于多線程。而且,當進程切換時,它們消耗更多的資源并且效率更高。
多進程、多線程:
多進程優(yōu)點:可以同時執(zhí)行多個任務,即協(xié)同工作。如果一起工作,效率也會更高。它的空間也是獨立的,如上所述,創(chuàng)建起來也比較方便。
多進程缺點:創(chuàng)建和銷毀進程需要大量的計算機資源,如果我們需要頻繁的創(chuàng)建和銷毀很多進程,就會造成資源消耗過多。因此,多進程不適合完成任務。
多線程優(yōu)點:提高程序效率,提高資源(CPU、內(nèi)存)的利用率,線程中的任務執(zhí)行完后,線程會自動銷毀,無需手動移除。
多線程缺點:開啟線程需要一定的內(nèi)存空間,如果需要開啟大量線程,肯定會占用大量內(nèi)存空間,從而降低性能。線程越多,CPU使用率越高。涉及的程序會比較復雜,比如通訊、數(shù)據(jù)共享等。
那么回到Python,如何使用Python線程呢?當我們的解釋器執(zhí)行代碼時,它會生成一個GIL鎖。在Python中,在執(zhí)行線程之前,必須獲取GIL鎖。每一段代碼執(zhí)行完后,解釋器會自動釋放GIL鎖去執(zhí)行其他線程。請注意,線程只能在Python中交替執(zhí)行。即使在100核CPU上運行100個線程,也只能使用1個核。Python雖然不能在多線程中實現(xiàn)多核任務,但是可以通過多個進程來實現(xiàn)多核任務。