进程
进程是系统资源分配的最小单位,一个运行的程序就是一个进程的实例,进程拥有自己独立的内存空间,所以进程间数据不共享,资源开销大。
进程之间通过multiprocessing模块的Queue队列进行通信。
进程可以使用多核CPU。
进程适用于CPU计算密集型的场景。
线程
线程是CPU调度执行的最小单位,不能独立存在,依赖进程存在, 一个进程至少有一个线程,而多个线程共享数据,共享全局变量, 资源开销小。
线程之间共享数据,所以会产生资源竞争。为了避免这个问题,所以线程有GIL锁(全局解释器锁)和互斥锁。
线程的多线程其实是伪多线程,是并发的。
线程适用于I/O读写操作耗时较多的场景。
协程
是一种用户级的轻量级线程,协程的调度完全由用户控制, 资源开销很小。
协程是属于单线程下的。