进程、线程和协程
- 进程是资源分配的单位;
- 线程是CPU调度的单位;
- 协程是一种比线程更加轻量级的存在,协程不是被操作系统内核所管理,而完全是由程序所控制(也就是在用户态执行)
线程与进程的区别:
- 地址空间:线程是进程内的一个执行单元,进程内至少有一个线程,它们共享进程的地址空间,而进程有自己独立的地址空间
- 资源拥有:进程是资源分配和拥有的单位,同一个进程内的线程共享进程的资源
- 线程是处理器调度的基本单位,但进程不是
- 二者均可并发执行
- 每个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口,但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制
协程与线程的区别:
- 一个线程可以多个协程,一个进程也可以单独拥有多个协程。
- 线程进程都是同步机制,而协程则是异步。
- 协程能保留上一次调用时的状态,每次过程重入时,就相当于进入上一次调用的状态。
- 线程是抢占式,而协程是非抢占式的,所以需要用户自己释放使用权来切换到其他协程,因此同一时间其实只有一个协程拥有运行权,相当于单线程的能力。
- 协程并不是取代线程, 而且抽象于线程之上, 线程是被分割的CPU资源, 协程是组织好的代码流程, 协程需要线程来承载运行, 线程是协程的资源, 但协程不会直接使用线程, 协程直接利用的是执行器(Interceptor), 执行器可以关联任意线程或线程池, 可以使当前线程, UI线程, 或新建新程.。
- 线程是协程的资源。协程通过Interceptor来间接使用线程这个资源。
一个进程 可以 拥有多个协程
一个线程 可以 拥有多个协程
进程和线程 是同步机制、协程是异步机制;
线程是抢占式
进程 一个人干一件事 管理者
线程池 一个人带着一帮小弟 干多件事 执行者
协程上下文 一个人带着一帮小弟 干一件事
| 进程 | 线程 | 协程 | |
|---|---|---|---|
| 概念 | 资源分配的单位 | CPU调度的单位 | 一种比线程更加轻量级的存在, 不被操作系统内核所管理, 完全是由程序所控制(也就是在用户态执行) |
| 地址空间 | |||
| 资源拥有 | |||
| 机制 | 同步 | 同步 | 异步 |
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来源 Michael's Blog!
评论



