进程、线程、协程的定义
进程,是操作系统资源分配和调度的一个独立单位,是系统资源分配的最小单位。进程一般是由代码、数据和进程空间三部分组成。进程在内存中有自己独立的内存空间(堆)。
进程的状态
线程是CPU的调度执行的最小单位,一个标准的线程由线程ID、当前指令指针(PC)、寄存器和堆栈组成。一个进程可以包含多个线程,线程之间共享进程的内存空间。
线程的状态
协程,英文是Coroutines,是一种基于线程之上,但又比线程更加轻量级的存在,由程序员自己写程序来管理的基于用户空间的协程,不需要经过的内核(CPU)的调度,完全是有程序所控制在用户态执行,不像线程调度的时候需要进行上下文切换,消耗CPU资源以及更多的时间。
协程可以帮助我们再一个线程执行的函数中,在任何地方保存当前函数的一些临时变量信息,然后切换到另一个函数中执行,这不是通过调用函数的方式来执行的,并且切换的次数以及什么时候再切换到原来的函数都是由开发者自己确定。
二进程、线程、协程的关系
进程、线程、协程的关系
进程在系统的表现就是一个独立服务,有单独的进程号存在,在linux系统中可以通过 ps -ef 查看
线程必须依附于进程而存在。
三、进程、线程、协程的优缺点
进程与线程的对比
线程和协程对比