(轉)並行與並發的區別


 

在研究CMS和G1垃圾收集器的區別時:G1的並行於並發把我搞糊塗了,接下來就深究一番

轉:https://blog.csdn.net/java_zero2one/article/details/51477791這個博主寫的比較通俗易懂,推薦大家看看

 

並發是多線程中的名詞,多線程發生的過程是:多線程是通過線程輪流切換來獲取CPU執行時間的

一、區別:

並發是指一個處理器同時處理多個任務。 
並行是指多個處理器或者是多核的處理器同時處理多個不同的任務。 
並發是邏輯上的同時發生(simultaneous),而並行是物理上的同時發生。 
來個比喻:並發是一個人同時吃三個饅頭,而並行是三個人同時吃三個饅頭。 

二、圖解:

並行(parallel):指在同一時刻,有多條指令在多個處理器上同時執行。就好像兩個人各拿一把鐵杴在挖坑,一小時后,每人一個大坑。所以無論從微觀還是從宏觀來看,二者都是一起執行的。 

 

並發(concurrency):指在同一時刻只能有一條指令執行,但多個進程指令被快速的輪換執行,使得在宏觀上具有多個進程同時執行的效果,但在微觀上並不是同時執行的,只是把時間分成若干段,使多個進程快速交替的執行。這就好像兩個人用同一把鐵杴,輪流挖坑,一小時后,兩個人各挖一個小一點的坑,要想挖兩個大一點得坑,一定會用兩個小時。 

並行在多處理器系統中存在,而並發可以在單處理器和多處理器系統中都存在,並發能夠在單處理器系統中存在是因為並發是並行的假象,並行要求程序能夠同時執行多個操作,而並發只是要求程序假裝同時執行多個操作(每個小時間片執行一個操作,多個操作快速切換執行)。

三、在一個CPU或多個CPU的情況下:

當有多個線程在操作時,如果系統只有一個CPU,則它根本不可能真正同時進行一個以上的線程,它只能把CPU運行時間划分成若干個時間段,再將時間段分配給各個線程執行,在一個時間段的線程代碼運行時,其它線程處於掛起狀態.這種方式我們稱之為並發(Concurrent)。

當系統有一個以上CPU時,則線程的操作有可能非並發.當一個CPU執行一個線程時,另一個CPU可以執行另一個線程,兩個線程互不搶占CPU資源,可以同時進行,這種方式我們稱之為並行(Parallel)。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM