并发(concurrent)、并行(parallel)、顺序(sequential)、串行(serial)是什么 区别

一、顺序和并发是指多个任务能否同时开始

1. 顺序(sequential)

顺序:上一个开始执行的任务完成后,当前任务才能开始执行。

2. 并发(concurrent)

并发:无论上一个开始执行的任务是否完成,当前任务都可以开始执行

A B 顺序执行的话,A 一定会比 B 先完成,而并发执行则不一定。

二、串行和并行是指任务多个任务能否同时执行

1. 串行(serial)

串行:有一个任务执行单元,从物理上就只能一个任务、一个任务地执行

2. 并行(parallel)

并行:有多个任务执行单元,从物理上就可以多个任务一起执行

在任意时间点上,串行执行时必然只有一个任务在执行,而并行则不一定。

三、并发(concurrent)和并行(parallel)的关系

rlang 之父 Joe Armstrong 用一张5岁小孩都能看懂的图解释了并发与并行的区别
在这里插入图片描述

并发的关键是你有处理多个任务的能力,不一定要同时。关注的是任务的抽象调度。
并行的关键是你有同时处理多个任务的能力。关注的是任务的实际执行。

如并行一定会允许并发。

并发和并行都可以是很多个线程,就看这些线程能不能同时被(多个)cpu执行,如果可以就说明是并行,而并发是多个线程被(一个)cpu 轮流切换着执行。

所以我认为它们最关键的点就是:是否是『同时』。

并行必须多核CPU才能办到,并发单核就可以做到(并发宏观并行,微观串行)。

并行是并发的子集,并发不一定并行,并行一定属于并发。

多线程在多核上同时运行的是并行.

单核 CPU 多任务:

并发(不必等上一个任务完成才开始下一个任务)、串行(只有一个实际执行任务的 CPU 核)

多线程:

并发、串行(所有线程都在同一个核上执行);

并发、并行(不同线程在不同的核上执行)

并发线程的执行顺序由cpu线程调度器决定,每个线程分一定时间片,执行一定时间后由线程调度器切换线程执行。

就是cpu计算太快,有时候请求内存或网络请求需要等待,这个时间cpu就可以切换别的线程进行计算,提高效率。

原文链接:https://blog.csdn.net/u013288190/article/details/114257211

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值