Python【每日一问】12

问:请解释线程、进程、协程

答:

【定义】

进程

进程:一个运行的程序(代码)就是一个进程,进程是系统资源分配的最小单位。进程拥有自己独立的内存空间,多个进程间资源不共享

线程

线程:调度执行的最小单位,也叫执行路径,不能独立存在,依赖进程存在。一个进程里至少有一个线程,叫主线程,一个进程里所有线程共享资源(数据共享,共享全局变量),从而极大地提高了程序的运行效率。

协程

协程:又称微线程,是一种用户态的轻量级线程,协程的调度完全由用户控制。协程的本质是个单线程。

【资源共享是否共享】

进程

进程:进程拥有自己独立的内存空间,用于存储自身的运行状态、数据及相关代码。一个进程一般不会直接读取其他进程的内存空间,即多个进程间资源不共享

线程

线程:一个进程里至少有一个线程,叫主线程,一个进程里的所有线程共享同一个进程的内存空间,从而极大地提高了程序的运行效率。

协程

协程:协程拥有自己的寄存器上下文和栈。协程调度切换时,将寄存器上下文和栈保存到其他地方,在切回来的时候,恢复先前保存的寄存器上下文和栈,直接操作栈则基本没有内核切换的开销,可以不加锁的访问全局变量,所以上下文的切换非常快。
原文地址:https://www.cnblogs.com/ElegantSmile/p/10782383.html