多线程相关
进程是一段运行的程序
线程是进程的分支,多线程可以提高程序的运行效率,提高并发。
import os
print(os.getpid()) #可以获得一个进程号
我们使用的计算机大多为单cpu计算机,单cpu计算机在一个时间点上只能处理一个任务。
GIL全局解释器锁,当一个事件运行加锁后,该事件的锁被释放之前,其他事件无法打断该事件的运行。
所以真正的并发在python中并不存在,采用的是时间片的形式的异步并发---伪并发。
异步并发:假设有任务A和任务B
把任务A分为A1,A2,A3......
把任务B分为B1,B2,B3......,异步是把这些子任务混合执行。
或者假设吃饭是一个进程,这一进程下分为三个线程:1.吃火烧,2.吃夫妻肺片,3.喝鱼丸汤
异步并发是,夹起来一口夫妻肺片,咬了口火烧,又喝了口汤,以免干着。