前言
在执行一些 IO 密集型任务的时候,程序常常会因为等待 IO 而阻塞
在了解进程,线程,协程以及它们关系之前,需要先了解以下概念
阻塞
阻塞状态指程序未得到所需计算资源时被挂起的状态。程序在等待某个操作完成期间,自身无法继续干别的事情,则称该程序在该操作上是阻塞的。 常见的阻塞形式有:网络 I/O 阻塞、磁盘 I/O 阻塞、用户输入阻塞等。阻塞是无处不在的,包括 CPU 切换上下文时,它们也会被阻塞。
非阻塞
程序在等待过程中,其自身不被阻挡,仍然可以干别的事情,则将其称之为非阻塞。
同步
多个不同的程序为了完成某一个目标,且完成该目标必须要按照指定步骤一点点进行,那我们就将这些程序称之为同步执行的。例如电商平台中的订单库存信息,要让不同的人针对同一个库存信息,此时就必须使用行级锁将库存表的更新操作强制按照顺序执行,不然就会出现订单与库存不符的情况出现。
异步
多个不同的程序为了完成某一个目标,但实现该目标的各步骤之间没有任何联系,可以各自独立执行,我们将这种运行方式称之为异步。例如,我们要爬取百度图片,此时各个图片之间并没有任何联系,我们就可以使用异步方式处理,会加快爬取速度,缩短用时。
进程
进程特点:
1,资源分配的最小单位
2,拥有独立的地址空间
3,可以在任务管理器中直观的看出来
4,动态性:进程是程序的一次执行过程,是临时的,有生命期的,是动态产生,动态消亡的
5,并发性:任何进程都可以同其他进程一起并发执行
6,独立性:进程是系统进行资源分配和调度的一个独立单位
7,结构性:进程由程序、数据和进程控制块三部分组
进程间通信:
1,管道
2,信号量
3,消息队列
4,共享内存
5,套接字
6,命名管道
多进程就是利用 CPU 的多核优势,在同一时间并行地执行多个任务,可以大大提高执行效率。
线程
线程特点:
1,轻量级进程
2,操作系统调度执行的最小单位
协程
协程特点:
1,程序控制
2,比线程更轻
3,切换更加方便
4,协程执行过程中可以中断去执行另一个协程子程序,在合适的时候返回继续执行
5,极高的执行效率
6,不需要多线程的锁机制
关系
1,一个进程可以包含多个线程,一个线程可以包含多个协程
2,进程和线程均为系统调用,协程为程序调用
3,进程是拥有资源的独立单位,线程和协程不拥有系统资源,但是可以访问隶属于进程的资源
4,进程维护的是该进程包含的静态资源,如:地址空间,文件系统状态,信号处理等信息,线程维护的是动态资源,如:调度相关信息,待处理的信号集等信息
5,进程为拥有资源,系统分配资源的最小单位,线程为系统调度的最小单位
6,进程,线程,协程切换开销以此递减
7,一个线程只属于一个进程,一个进程可以包含多个线程,但一个进程最小应包含一个线程
8,资源分配的目标为进程,但处理机真正分配执行任务的是线程
9,线程在执行过程中,需要协作时,不同进程之间的线程需要通过进程的消息通信来实现