国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

理論講解python多進程并發編程

2020-02-22 23:11:45
字體:
來源:轉載
供稿:網友

一、什么是進程

進程:正在進行的一個過程或者說一個任務。而負責執行任務則是cpu。

二、進程與程序的區別

程序:僅僅是一堆代

進程:是指打開程序運行的過程

三、并發與并行

并發與并行是指cpu運行多個程序的方式

不管是并行與并發,在用戶看起來都是‘同時'運行的,他們都只是一個任務而已,正在干活的是cpu,而一個cpu只能執行一個任務。

并行就相當于有好多臺設備,可以同時供好多人使用。

而并發就相當于只有一臺設備,供幾個人輪流用,每個人用一會就換另一個人。

所以只有多個cpu才能實現并行,而一個cpu只能實現實現并發。

如上圖所示:

串行:執行完A,再執行B,再執行C

并行:同時執行ABC

并發:交替執行ABC

四、同步/異步

并發與并行是指cpu運行多個程序的方式,而同步和異步是指一個程序的執行過程

 同步:所謂同步,就是在發出一個功能調用時,在沒有得到結果之前,該調用就不會返回。

按照這個定義,其實大部分函數都是同步調用,但是一般而言,我們說同步和異步的時候,

特指哪些需要其他部件協作或者需要一定時間完成的任務

異步:異步的概念和同步相對,當一個異步功能調用發出后,調用者不能立即得到結果

當該異步功能完成后,通過狀態。通知或回調來通知調用者。如果異步功能用狀態來通知,那么

調用者就需要每隔一定時間檢查一次,效率就回很低,如果使用通知的方式,效率就回很高,

因為異步功能幾乎不需要做額外的操作,至于回調函數,其實和通知沒太大區別。

五、阻塞/非阻塞

阻塞:阻塞調用是指調用結果返回之前,當前線程會被掛起(如遇到IO操作)。

函數只有得到結果之后才會被阻塞的線程激活。

非阻塞:非阻塞和阻塞的概念相對,指在不能立即得到結果之前也會立即返回,同時該函數不會阻塞當前線程

小結:同步與異步針對的是函數/任務的調用方式:同步就是當一個進程發起一個函數調用的時候,一直等到函數/任務完成,

而進程繼續處于激活狀態。而異步情況下是當一個進程發起一個函數|任務調用的時候,不會等函數返回,而繼續往下執行,

函數返回的時候通過狀態、通知、時間等方式通知進程任務完成

而阻塞和非阻塞是針對進程或者線程,阻塞是當請求不能滿足的時候就掛起,而非阻塞則不會阻塞當前的進程

六、進程的創建與終止(了解)

進程的創建:

但凡是硬件,都需要有操作系統去管理,只要有操作系統,就有進程的概念,就需要有創建進程的方式,一些操作系統只為一個應用程序設計,比如微波爐中的控制器,一旦啟動微波爐,所有的進程都已經存在。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 凤翔县| 广州市| 准格尔旗| 浮山县| 新巴尔虎右旗| 陆良县| 礼泉县| 乐清市| 广州市| 汨罗市| 汕头市| 宝山区| 喀喇沁旗| 中阳县| 洛扎县| 五华县| 喀喇沁旗| 高邑县| 工布江达县| 文山县| 镇赉县| 博罗县| 南召县| 安义县| 巫溪县| 巴彦县| 剑河县| 温泉县| 馆陶县| 防城港市| 无极县| 大邑县| 胶南市| 农安县| 彰化县| 济源市| 信丰县| 平遥县| 平泉县| 文安县| 宕昌县|