并发和并行的区别_Concurrency & Parallelism

并发和并行的区别_Concurrency & Parallelism

并发(Concurrency)和并行(Parallel)的区别

这两个单词的读音:

  • Concurrency:[kən'kʌrənsɪ] 并发

  • Parallel:[ˈpærəˌlɛl] 平行线-并行


并发(Concurrency)和并行(Parallel

当有多个线程在操作时,如果系统只有一个CPU,则它根本不可能真正同时进行一个以上的线程,它只能把CPU运行时间划分成若干个时间段,再将时间段分配给各个线程执行,在一个时间段的线程代码运行时,其它线程处于挂起状态.这种方式我们称之为并发(Concurrent).

系统有一个以上CPU时,则线程的操作有可能非并发.当一个CPU执行一个线程时,另一个CPU可以执行另一个线程,两个线程互不抢占CPU资源,可以同时进行,这种方式我们称之为并行(Parallel)


并发和并行的区别_Concurrency & Parallelism_第1张图片


多线程在并发和并行环境中的不同作用

在并发环境时,多线程不可能真正充分利用CPU,节约运行时间,它只是以”挂起->执行->挂起”的方式以很小的时间片分别运行各个线程,给用户以每个线程都在运行的错觉.在这种环境中,多线程程序真正改善的是系统的响应性能和程序的友好性。

在并行环境中, 一个时刻允许多个线程运行,这时多线程程序才真正充分利用了多CPU的处理能力, 节省了整体的运行时间.在这种环境中,多线程程序能体现出它的四大优势:充分利用CPU,节省时间,改善响应和增加程序的友好性。


最后再上一张图:

并发和并行的区别_Concurrency & Parallelism_第2张图片

=====END=====

你可能感兴趣的:(并发和并行的区别_Concurrency & Parallelism)