1.什么是进程、线程和协程
进程是系统进行资源分配和调用的基本单位,每一个进程都有它自己的内存空间和系统资源。
线程是进程的执行单元或者执行路线,线程也是CPU调度的基本单位。
协程是用户态的轻量级线程,在理解用户态的线程之前,必须先了解什么是内核态线程,内核态线程是由操作系统负责调度的线程,利用时间片轮转的方式进行调度的,而用户态线程是由程序员调度的,操作系统对此一无所知,协程拥有自己的寄存器上下文和栈,协程调度切换时,会将寄存器上下文和栈保存起来,在切换回来的时候回复之前运行的状态。
程序调用进程,进程调用线程;一般来说程序下都是多进程,不同进程分工不同,每个进程下也基本都是多线程,每个线程可以有一个或者多个协程。
2.进程和线程的区别
- 进程是资源竞争的最小单位
- 线程是程序执行的最小单位
- 线程共享进程数据,同时也拥有自己一部分数据
3.线程和协程的区别
一旦创建了线程,你就无法知道它什么时候获得时间片,什么时候让出时间片,因为你把它交给了内核。而协程不仅有可控的切换时机,而且切换代价很小,因为它不需要CPU内部的调度切换。
4.三者的联系
三种调度的技术虽然有相似的地方,但并不冲突,进程调度可以很好的控制资源分配,线程调度让进程内部不会因为某个操作阻塞而整体阻塞,协程则是让用户态来优化程序,让程序员以同步代码的方式写出异步代码一般的效率。