Python进程、线程与协程

Python进程、 线程与协程


进程:

  进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。在早期面向进程设计的计算机结构中,进程是程序的基本执行实体;在当代面向线程设计的计算机结构中,进程是线程的容器。程序是指令、数据及其组织形式的描述,进程是程序的实体。

在这里插入图片描述

线程

  线程(英语:thread)是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务。在Unix System V及SunOS中也被称为轻量进程(lightweight processes),但轻量进程更多指内核线程(kernel thread),而把用户线程(user thread)称为线程。

在这里插入图片描述


协程

  一个程序可以包含多个协程,可以对比与一个进程包含多个线程,因而下面我们来比较协程和线程。我们知道多个线程相对独立,有自己的上下文,切换受系统控制;而协程也相对独立,有自己的上下文,但是其切换由自己控制,由当前协程切换到其他协程由当前协程来控制。

在这里插入图片描述

进程线程协程的区别

在这里插入图片描述

进程、线程、协程的区别:
进程是计算机中资源分配的最小单位。

线程是计算机中cpu资源调度的最小单位。

协程又称”微线程“,是在一条线程上来回切换来规避IO操作。在计算机中不是真实存在的,而是程序员通过代码伪造出来。

一个进程以可以开启多个线程、线程是依赖进程存在的、一个线程下可以创建多个协程。

在Cpython中存在GIL(全局解释器锁),它的作用保证在某一时刻下只有一个进程中的一个线程可以被CPU调度。由于GIL的存在,导致Python中计算密集型的任务使用进程,代码没有等待时间,发挥了多核性能,I/O密集型的任务使用线程或协程

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值