进程-线程-协程

前言

在执行一些 IO 密集型任务的时候,程序常常会因为等待 IO 而阻塞
在了解进程,线程,协程以及它们关系之前,需要先了解以下概念

阻塞

阻塞状态指程序未得到所需计算资源时被挂起的状态。程序在等待某个操作完成期间,自身无法继续干别的事情,则称该程序在该操作上是阻塞的。 常见的阻塞形式有:网络 I/O 阻塞、磁盘 I/O 阻塞、用户输入阻塞等。阻塞是无处不在的,包括 CPU 切换上下文时,它们也会被阻塞。

非阻塞

程序在等待过程中,其自身不被阻挡,仍然可以干别的事情,则将其称之为非阻塞。

同步

多个不同的程序为了完成某一个目标,且完成该目标必须要按照指定步骤一点点进行,那我们就将这些程序称之为同步执行的。例如电商平台中的订单库存信息,要让不同的人针对同一个库存信息,此时就必须使用行级锁将库存表的更新操作强制按照顺序执行,不然就会出现订单与库存不符的情况出现。

异步

多个不同的程序为了完成某一个目标,但实现该目标的各步骤之间没有任何联系,可以各自独立执行,我们将这种运行方式称之为异步。例如,我们要爬取百度图片,此时各个图片之间并没有任何联系,我们就可以使用异步方式处理,会加快爬取速度,缩短用时。

进程

进程特点:

	1,资源分配的最小单位
	2,拥有独立的地址空间
	3,可以在任务管理器中直观的看出来
	4,动态性:进程是程序的一次执行过程,是临时的,有生命期的,是动态产生,动态消亡的
	5,并发性:任何进程都可以同其他进程一起并发执行
	6,独立性:进程是系统进行资源分配和调度的一个独立单位
	7,结构性:进程由程序、数据和进程控制块三部分组

在这里插入图片描述
进程间通信:

	1,管道
	2,信号量
	3,消息队列
	4,共享内存
	5,套接字
	6,命名管道

多进程就是利用 CPU 的多核优势,在同一时间并行地执行多个任务,可以大大提高执行效率。

线程

线程特点:

	1,轻量级进程
	2,操作系统调度执行的最小单位

在这里插入图片描述

协程

协程特点:

	1,程序控制
	2,比线程更轻
	3,切换更加方便
	4,协程执行过程中可以中断去执行另一个协程子程序,在合适的时候返回继续执行
	5,极高的执行效率
	6,不需要多线程的锁机制

关系

	1,一个进程可以包含多个线程,一个线程可以包含多个协程
	2,进程和线程均为系统调用,协程为程序调用
	3,进程是拥有资源的独立单位,线程和协程不拥有系统资源,但是可以访问隶属于进程的资源
	4,进程维护的是该进程包含的静态资源,如:地址空间,文件系统状态,信号处理等信息,线程维护的是动态资源,如:调度相关信息,待处理的信号集等信息
	5,进程为拥有资源,系统分配资源的最小单位,线程为系统调度的最小单位
	6,进程,线程,协程切换开销以此递减
	7,一个线程只属于一个进程,一个进程可以包含多个线程,但一个进程最小应包含一个线程
	8,资源分配的目标为进程,但处理机真正分配执行任务的是线程
	9,线程在执行过程中,需要协作时,不同进程之间的线程需要通过进程的消息通信来实现
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值