python多线程和多进程的区别_python中多线程与多进程的区别
線程的概念:
線程是操作系統(tǒng)中進(jìn)行運(yùn)算調(diào)度的最小單位。它被包含在進(jìn)程之中,是進(jìn)程中的實(shí)際運(yùn)作單位。一條線程指的是進(jìn)程中一個單一順序的控制流,一個進(jìn)程可以有多個線程,每條線程可以同時(shí)執(zhí)行不同的任務(wù)。一個線程可以看作一個cpu執(zhí)行時(shí)所需要的一串指令
多線程
在Python的標(biāo)準(zhǔn)庫中提供了兩個模塊:_thread和threading,_thread是低級模塊不支持守護(hù)線程,當(dāng)主線程退出時(shí),所有子線程都會被強(qiáng)行退出。而threading是高級模塊,用于對_thread進(jìn)行了封裝支持守護(hù)線程。在大多數(shù)情況下我們只需要使用threading這個高級模塊即可。
進(jìn)程的概念:
進(jìn)程指的是一個程序在給定數(shù)據(jù)集合上的一次執(zhí)行過程,是系統(tǒng)進(jìn)行資源分配和運(yùn)行調(diào)用的獨(dú)立單位。也就是每一個應(yīng)用程序都有一個自己的進(jìn)程。進(jìn)程在啟動時(shí)都會最先產(chǎn)生一個線程,這個線程被稱為主線程,然后再有主線程創(chuàng)建其他子線程
多進(jìn)程:
多進(jìn)程是multiprocessing模塊提供遠(yuǎn)程與本地的并發(fā),在一個multiprocessing庫的使用場景下,所有的子進(jìn)程都是由一個父進(jìn)程啟動來的,這個父進(jìn)程成為madter進(jìn)程,它會管理一系列的對象狀態(tài),一旦這個進(jìn)程退出,子進(jìn)程很可能處于一個不穩(wěn)定的狀態(tài),所以這個父進(jìn)程盡量要少做事來保持其穩(wěn)定性
線程與進(jìn)程的區(qū)別
(1)線程必須在某個進(jìn)程中執(zhí)行。一個進(jìn)程可包含多個線程,并且只有一個主線程。
(2)多線程共享同個地址空間、打開的文件以及其他資源。而多進(jìn)程共享物理內(nèi)存、磁盤、打印機(jī)以及其他資源。
(3)線程幾乎不占資源,系統(tǒng)開銷少,切換速度快,而且同個進(jìn)程中的多個線程可以實(shí)現(xiàn)數(shù)據(jù)共享,而進(jìn)程之間是不可共享的
(4)新線程的創(chuàng)建很簡單而新進(jìn)程的創(chuàng)建需要對父進(jìn)程進(jìn)行克隆
(5)一個線程可以控制和操作同一進(jìn)程里的其他線程;但是進(jìn)程只能操作子進(jìn)程
總結(jié)
以上是生活随笔為你收集整理的python多线程和多进程的区别_python中多线程与多进程的区别的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: fastreport文本字数太多换行_F
- 下一篇: python选课系统_【精选】在Mona