併發與並行的區別

2021-09-19 13:53:25 字數 965 閱讀 1915

並行是指兩個或者多個事件在同一時刻發生;而併發是指兩個或多個事件在同一時間間隔發生。

並行是在不同實體上的多個事件,併發是在同一實體上的多個事件。

並行是在一台處理器上「同時」處理多個任務,併發是在多台處理器上同時處理多個任務。

所以併發程式設計的目標是充分的利用處理器的每乙個核,以達到最高的處理效能。

並行(parallel):指在同一時刻,有多條指令在多個處理器上同時執行。所以無論從微觀還是從巨集觀來看,二者都是一起執行的。

併發(concurrency):指在同一時刻只能有一條指令執行,但多個程序指令被快速的輪換執行,使得在巨集觀上具有多個程序同時執行的效果,但在微觀上並不是同時執行的,只是把時間分成若干段,使多個程序快速交替的執行。

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

當有多個執行緒在操作時,如果系統只有乙個 cpu,則它根本不可能真正同時進行乙個以上的執行緒,它只能把 cpu 執行時間劃分成若干個時間段,再將時間段分配給各個執行緒執行,在乙個時間段的執行緒**執行時,其它執行緒處於掛起狀態.這種方式我們稱之為併發(concurrent)。

當系統有乙個以上 cpu 時,則執行緒的操作有可能非併發。當乙個 cpu 執行乙個執行緒時,另乙個 cpu 可以執行另乙個執行緒,兩個執行緒互不搶占 cpu 資源,可以同時進行,這種方式我們稱之為並行(parallel)。

併發與並行區別

併發當有多個執行緒在操作時,如果系統只有乙個cpu,則它根本不可能真正同時進行乙個以上的執行緒,它只能把cpu執行時間劃分成若干個時間段,再將時間 段分配給各個執行緒執行,在乙個時間段的執行緒 執行時,其它執行緒處於掛起狀。這種方式我們稱之為併發 concurrent 並行 當系統有乙個以上cpu時...

區別 併發與並行

所有的併發處理都有排隊等候,喚醒,執行至少三個這樣的步驟.所以併發肯定是巨集觀概念,在微觀上他們都是序列被處理的,只不過資源不會在某乙個上被阻塞 一般是通過時間片輪轉 所以在巨集觀上看多個幾乎同時到達的請求同時在被處理。如果是同一時刻到達的請求也會根據優先順序的不同,而先後進入佇列排隊等候執行。併發...

並行與併發的區別

併發性和並行性的區別可以用饅頭做比喻。前者相當於乙個人同時吃三個饅頭,而後者相當於三個人同時吃乙個饅頭。併發性 concurrence 指兩個或兩個以上的事件或活動在同一時間間隔內發生。併發的實質是乙個物理cpu 也可以多個物理cpu 在若干道程式之間多路復用,併發性是對有限物理資源強制行使多使用者...