- 进程
进程是一种抽象概念,是操作系统进行资源分配与调度的独立单元,所以进程会有自己独立的地址空间与堆。当一个应用程序打开时就会分配一个或多个进程。进程之间的内存是相互隔离的。
- 线程
线程是计算机调度的最小单元。早期没有线程概念时也叫作微进程。一个进程可以拥有多个线程,他们共享进程的内存空间
- 协程
协程是比线程更加轻量级,是由程序控制的,即用户态。协程不会像线程抢占式任务,而是让度式的。在运行中是可以随时中断,让度使用权,当别的任务运行完后转而回来执行。
极高的执行效率:因为子程序切换不是线程切换,而是由程序自身控制,因此,没有线程切换的开销,和多线程比,线程数量越多,协程的性能优势就越明显;
不需要多线程的锁机制:因为只有一个线程,也不存在同时写变量冲突,在协程中控制共享资源不加锁,只需要判断状态就好了,所以执行效率比多线程高很多。
协程的出现就是为了更好的利用CPU执行效率,充分利用CPU的性能。那我们就需要了解下另外两个词:并发 、 并行
并发:多个任务交替使用CPU,一个时间段内只能执行一个任务。
并行: 多个任务同时在多个CPU中执行,关健字:同时, 一个时间段内可能执行多个任务。
看过一个很形象的例子:
一个人在吃饭,电话来了,
等吃完饭再接电话,没有并发也没有并行;
先接电话,接完电话,再来吃饭,并发没有并行;
一边接电话,一边吃饭,并行;
参考:
http://www.360doc.com/content/20/0417/14/32196507_906628857.shtml
https://blog.csdn.net/daaikuaichuan/article/details/82951084