进程、线程和协程的区别和联系
空白 | 进程 | 线程 | 协程 |
---|---|---|---|
定义 | 进程是资源分配的单位 | 线程是CPU调度的基本单位 | 协程是用户态的轻量级线程,线程内部调度的基本单位 |
切换情况 | 进程CPU环境(栈、寄存器、页表和文件句柄等)的保存以及新调度的进程CPU环境的设置 | 线程保存寄存器和栈的内容,程序计数器 | 协程先将寄存器上下文和栈保存,等切换回来再进行恢复 |
切换者 | 操作系统 | 操作系统 | 用户 |
切换过程 | 用户态-》内核态-》用户态 | 用户态-》内核态-》用户态 | 协程只有用户态 |
调用栈 | 内核栈 | 内核栈 | 用户栈 |
拥有资源 | CPU资源、内存资源、文件资源和句柄 | 程序计数器、寄存器、栈和状态字 | 拥有自己的寄存器上下文和栈。 |
并发性 | 不同进程之间切换实现并发,各自占有CPU并实现并行 | 一个进程内部多个线程并发执行 | 同一时间只能执行一个协程,而其他协程处于休眠状态,适合对任务进行分时处理 |
系统开销 | 切换虚拟地址空间、内核栈和硬件上下文,CPU高速缓存、页表切换,开销很大 | 切换时只需保存和设置少量寄存器内容,因此开销很小 | 直接操作栈没有内核切换的开销,可不加锁访问全局变量,上下文切换非常快 |
通信方面 | 进程间通信需要借助操作系统 | 线程间可直接读写全局变量来进行通信 | 共享内存、消息队列 |
资料来源: 拓跋阿秀的整理pdf