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

首頁 > 編程 > Python > 正文

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

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

一、什么是進程

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

二、進程與程序的區別

程序:僅僅是一堆代

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

三、并發與并行

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

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

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

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

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

如上圖所示:

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

并行:同時執行ABC

并發:交替執行ABC

四、同步/異步

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

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

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

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

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

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

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

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

五、阻塞/非阻塞

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

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

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

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

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

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

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

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

進程的創建:

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 莱阳市| 西昌市| 金堂县| 辽源市| 灵宝市| 日喀则市| 南宫市| 深圳市| 晴隆县| 克什克腾旗| 东海县| 衡山县| 崇礼县| 伊通| 乌鲁木齐县| 靖西县| 贺州市| 嵊泗县| 泰来县| 芮城县| 当阳市| 灵丘县| 巫山县| 弥渡县| 东乡县| 夹江县| 龙井市| 祁连县| 洛浦县| 盐山县| 喀喇沁旗| 福建省| 潮安县| 团风县| 习水县| 慈利县| 荣昌县| 花莲县| 松滋市| 淮滨县| 乌兰县|