欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

深入浅出理解同步 /异步/并发/并行/串行

程序员文章站 2022-07-23 21:20:44
(1)从线程的时效来看:分为同步和异步 同步:多个任务情况下,一个任务A执行结束,才可以执行另一个任务B。只存在一个线程。 异步:多个任务情况下,一个任务A正在执行,同时可以执行另一个任务B。任务B不用等待任务A结束才执行。存在多条线程。 (2)从线程的执行来看:分为串行队列和并行队列 串行队列:串 ......

(1)从线程的时效来看:分为同步和异步

同步:多个任务情况下,一个任务A执行结束,才可以执行另一个任务B。只存在一个线程。

异步:多个任务情况下,一个任务A正在执行,同时可以执行另一个任务B。任务B不用等待任务A结束才执行。存在多条线程。

(2)从线程的执行来看:分为串行队列和并行队列

串行队列:串行队列的特点是队列内的线程是一个一个执行,直到结束。

并行队列:并行队列的特点是队列中所有线程的执行结束时必须是一块的,队列中其他线程执行完毕后,会阻塞当前线程等待队列中其他线程执行,然后一块执行完毕。

(3)线程的时效与执行相结合:

深入浅出理解同步 /异步/并发/并行/串行

图片来源:https://blog.csdn.net/l540675759/article/details/62932901

(1)串行同步 
图1是串行同步的情况,队列中的线程依次执行,并且主线程阻塞,等待任务的完成。

(2)并行同步 
图3是并行同步的情况,队列中的线程,会一起执行,但是同一时段只能有一个线程执行其他线程等待,等所有任务执行完,主线程继续执行。

同步(单线程)的串行并行区别在于:

1.并行增加了等待时间,如果等待时间到了,任务还在执行,那么,重新设置等待时间,继续等待,不管等待的时候线程是否有空闲。

2.串行是对线程进行阻塞,一个任务执行完毕,线程不再阻塞,所以,不存在等待时间。

(3)串行异步 
图2是串行异步的情况,队列中的线程依次执行,同时主线程还在继续执行。

(4)并行异步 
图4是并行异步的情况,队列中的线程,一起执行,主线程也会继续执行。

异步(多线程)的串行并行区别在于:

1.串行异步只占用两个线程,一个主线程,不会阻塞的线程,一个次线程,执行原理和同步串行一样。

2.并行异步占用N个线程,多核CUP可以同时开启多条线程供多个任务同时执行,互不干扰。

 

(4)同步的并行即为并发(常见于es7的async await与node的单线程)。