進程:正在進行的一個過程或者說一個任務。而負責執行任務則是cpu。
程序:僅僅是一堆代
進程:是指打開程序運行的過程
并發與并行是指cpu運行多個程序的方式
不管是并行與并發,在用戶看起來都是‘同時'運行的,他們都只是一個任務而已,正在干活的是cpu,而一個cpu只能執行一個任務。
并行就相當于有好多臺設備,可以同時供好多人使用。
而并發就相當于只有一臺設備,供幾個人輪流用,每個人用一會就換另一個人。
所以只有多個cpu才能實現并行,而一個cpu只能實現實現并發。

如上圖所示:
串行:執行完A,再執行B,再執行C
并行:同時執行ABC
并發:交替執行ABC
并發與并行是指cpu運行多個程序的方式,而同步和異步是指一個程序的執行過程
同步:所謂同步,就是在發出一個功能調用時,在沒有得到結果之前,該調用就不會返回。
按照這個定義,其實大部分函數都是同步調用,但是一般而言,我們說同步和異步的時候,
特指哪些需要其他部件協作或者需要一定時間完成的任務
異步:異步的概念和同步相對,當一個異步功能調用發出后,調用者不能立即得到結果
當該異步功能完成后,通過狀態。通知或回調來通知調用者。如果異步功能用狀態來通知,那么
調用者就需要每隔一定時間檢查一次,效率就回很低,如果使用通知的方式,效率就回很高,
因為異步功能幾乎不需要做額外的操作,至于回調函數,其實和通知沒太大區別。
阻塞:阻塞調用是指調用結果返回之前,當前線程會被掛起(如遇到IO操作)。
函數只有得到結果之后才會被阻塞的線程激活。
非阻塞:非阻塞和阻塞的概念相對,指在不能立即得到結果之前也會立即返回,同時該函數不會阻塞當前線程
小結:同步與異步針對的是函數/任務的調用方式:同步就是當一個進程發起一個函數調用的時候,一直等到函數/任務完成,
而進程繼續處于激活狀態。而異步情況下是當一個進程發起一個函數|任務調用的時候,不會等函數返回,而繼續往下執行,
函數返回的時候通過狀態、通知、時間等方式通知進程任務完成
而阻塞和非阻塞是針對進程或者線程,阻塞是當請求不能滿足的時候就掛起,而非阻塞則不會阻塞當前的進程
進程的創建:
但凡是硬件,都需要有操作系統去管理,只要有操作系統,就有進程的概念,就需要有創建進程的方式,一些操作系統只為一個應用程序設計,比如微波爐中的控制器,一旦啟動微波爐,所有的進程都已經存在。
新聞熱點
疑難解答