顺序:上一个开始执行的任务完成后,当前任务才能开始执行。
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://www.zhihu.com/question/33515481