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

被折叠的 条评论
为什么被折叠?



