[并发概念] 串行、并行与并发

串行和并行

串行是排队一个一个处理任务,并行是同时处理多个任务。
在这里插入图片描述

并发和并行

概念非常相似,难以区分。分别体现在两个方面。

  • 并发(Concurrency),体现在(1)单个处理器;(2)逻辑上同步运行。
  • 并行(Parallelism),体现在(1)多处理器,多核心;(2)物理上同步运行。

并行的理解

并行,是真正的同时运行–在同一个时刻多个任务同时执行。例如多核处理器上,有多个线程同时执行同一段代码。单核处理器无法在同一时刻执行多个任务,因此无法并行。

并发的理解

并发有两种描述,一种是形容多个任务的执行状态;另一种是对“并发性”的简称。

多任务执行状态

因为处理器处理特别快,看上去像同步执行。

  • 两个或者多个任务可以在某个重叠的时间段中启动、运行、完成。
  • 并行(多个线程同时执行)一定是并发,两者是包含关系。

在这里插入图片描述

3个线程由一个CPU交替执行(并发)。
在这里插入图片描述

3个线程同时由多个CPU执行(并行且并发)。

“并发性”的简称

程序的部分可以无序或者同时执行,且不影响最终的执行结果,表示程序具有并发性。

“并发性”在不同核心数计算机上有着不同的表现。对于多核CPU,可以做到真实的同时运行,即并行;对于单核CPU,可以通过多个线程切换时间片交替运行,实现并发。

是什么让并发和并行成为了可能

  1. CPU的升级。单核CPU一次只能处理一条指令,基于此增加核心数,多线程处理任务,提高效率。
  2. 操作系统的升级。单核CPU可以通过抢占式调度实现多个线程的切换;多线程如何分配核心是有操作系统来决定,开发人员只需要创建并运行多个线程。
  3. 编程语言的升级–支持多线程。
发布了72 篇原创文章 · 获赞 110 · 访问量 9万+

猜你喜欢

转载自blog.csdn.net/LIZHONGPING00/article/details/103776649
今日推荐