心得
Part1: 多线程与多进程
Python 中,无论是单核还是多核,同时只能由一个线程在执行。主要是因为
GIL(Global Interpreter Lock),全局解释器锁,某个线程想要执行,必须先拿到 GIL,我们可以把 GIL 看作是“通行证”,并且在一个 Python 进程中,GIL 只有一个。拿不到通行证的线程,就不允许进入 CPU 执行。导致想要做到真正意义上的并行需要用多进程。
多线程:
Start()开始线程
setDaemon()守护线程,必须在start()之前使用,设置为True作用是跟随主线程一起结束,不管自身是否结束
join()阻塞,主线程等该子线程结束再继续
多进程:
Pool 多进程池
Process 创建进程
Value 设定多进程间通信变量
Queue 多进程间通信队列
Part2:
- Pyinstaller在打包多进程的时候,程序会出现不能正常运行,但是后台却启动了多个进程的情况。
解决方法:在if name == ‘main’ 里加上 multiprocessing.freeze_support()。 - Pyinstaller打包后的程序在运行时出现假死未响应但是后台可执行的情况。
解决方法:创建新的线程进行功能函数的执行