串行、并行、并发总结
舉個生活中的例子 :
你吃飯吃到一半,電話來了,你一直到吃完了以后才去接,這就說明你不支持并發也不支持并行。
你吃飯吃到一半,電話來了,你停了下來接了電話,接完后繼續吃飯,這說明你支持并發。
你吃飯吃到一半,電話來了,你一邊打電話一邊吃飯,這說明你支持并行。
并發的關鍵是你有處理多個任務的能力,不一定要同時。
并行的關鍵是你有同時處理多個任務的能力。
串行( Sequential )簡單來說就是一次只能做一件事情,而且還得按照順序依次執行,后面的代碼段必須等到前面代碼段的任務執行完畢后才能執行。
并行(parallel):指在同一時刻,有多條指令在多個處理器上同時執行。所以無論從微觀還是從宏觀來看,二者都是一起執行的。
并發(concurrency):指在同一時刻只能有一條指令執行,但多個進程指令被快速的輪換執行,使得在宏觀上具有多個進程同時執行的效果,但在微觀上并不是同時執行的,只是把時間分成若干段,使多個進程快速交替的執行。
并行在多處理器系統中存在,而并發可以在單處理器和多處理器系統中都存在,并發能夠在單處理器系統中存在是因為并發是并行的假象,并行要求程序能夠同時執行多個操作,而并發只是要求程序假裝同時執行多個操作(每個小時間片執行一個操作,多個操作快速切換執行)。
當有多個線程在操作時,如果系統只有一個 CPU,則它根本不可能真正同時進行一個以上的線程,它只能把 CPU 運行時間劃分成若干個時間段,再將時間段分配給各個線程執行,在一個時間段的線程代碼運行時,其它線程處于掛起狀態.這種方式我們稱之為并發(Concurrent)。
當系統有一個以上 CPU 時,則線程的操作有可能非并發。當一個 CPU 執行一個線程時,另一個 CPU 可以執行另一個線程,兩個線程互不搶占 CPU 資源,可以同時進行,這種方式我們稱之為并行(Parallel)。
總結
以上是生活随笔為你收集整理的串行、并行、并发总结的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python—操作MySQL增加数据
- 下一篇: python—操作MySQL查询表中数据