我们都知道,在操作系统的维度上,线程是CPU分配的最小单位。
并行就是同一时刻,两个线程都在执行。这就要求有两个 CPU 去分别执行两个线程。可理解为两个 CPU 服务两个线程,线程与服务器是一对一的关系。
并发就是同一时刻,只有一个执行,但是一个时间段内,两个线程都执行了。并发的实现依赖于 CPU 切换线程,因为切换的时间特别短,所以基本对于用户是无感知的。可以理解为一个 CPU 在为两个线程服务,CPU 在两个线程之间来回切换。
并发的实质是一个物理 CPU(也可以是多个物理CPU)在若干个程序之间多路复用,并发性是对有限物理资源强制行使多用户共享以提高效率。
并行指两个或两个以上事件或活动在同一时刻发生,在多道程序环境下,并行使多个程序同一时刻可在不同 CPU 上同时执行。
举个例子比如去食堂打饭,并行就是多个学个在多个窗口同时打饭,并发就是多个学生在同一个窗口同时打饭。
并行需要两个或两个以上的线程跑在不同的处理器上,并发可以跑在一个处理器上通过时间片进行切换。