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】小结

  • 线程是最小的执行单元
  • 一个进程可以包含多个线程
  • 进程与线程的调度完全由操作系统决定
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值