Python多进程和多线程(一):基础概念
多进程和多线程
现代的操作系统(例如:MaxOSX,Unix,Linux,Windows)都是支持多任务的,即操作系统可以同时运行多个任务
一边使用浏览器,一边听歌,一边写word……
【1】单核CPU
即使是单核cpu也可以执行多任务,虽然CPU在执行程序的时候都是顺序执行的,而单核CPU的操作系统会让各个任务交替执行
交替执行:任务1执行0.0001秒,任务2执行0.0002秒……每个任务都不是一次性执行完毕
由于CPU运行的速度非常快,虽然是交替执行的,但是从感官上每个任务看起来像是同时运行的
【2】多核CPU
单核CPU的多任务可以说是一种障眼法
真正的多任务执行只能发生在多核CPU上
操作系统自动将很多任务轮流调度到每个核心上运行
【3】进程(process)
对于操作系统而言:一个任务就是一个进程
打开一个浏览器,打开一个记事本,打开一个word……
在每一个进程中,内部还有许多的操作,这些操作就是线程
例如:一个word进程,里面还有插入、删除、打字……
【4】线程(thread)
一个进程至少有一个线程
对于一些复杂的进程,则一个进程可以有许多线程。多个线程是可以同时运行的,由操作系统在多个线程之间快速切换,让每个线程都短暂的交替执行,看起来向同时运行一样。
真正的多线程运行也只能发生在多核CPU上
例如:通过电脑看电影这是一个进程,与此同时还有视频线程,声音线程……
【5】多任务实现方式
- 多进程模式
- 多线程模式
- 多进程+多线程(太复杂,用的少)
多任务之间往往是有关联的,需要相互通信和协调
例:任务1等待任务2的资源释放……
【6】小结
- 线程是最小的执行单元
- 一个进程可以包含多个线程
- 进程与线程的调度完全由操作系统决定