Python并发编程1——进程的基本概念

并发编程

多任务编程

  1. 意义: 充分利用计算机多核资源,提高程序的运行效率。

  2. 实现方案 :多进程 , 多线程

  3. 并行与并发

并发 : 同时处理多个任务,内核在任务间不断的切换达到好像多个任务被同时执行的效果,实际每个时刻只有一个任务占有内核。

并行 : 多个任务利用计算机多核资源在同时执行,此时多个任务间为并行关系。

进程(process)

进程理论基础

  1. 定义 : 程序在计算机中的一次运行。
  • 程序是一个可执行的文件,是静态的占有磁盘。
  • 进程是一个动态的过程描述,占有计算机运行资源,有一定的生命周期。
  1. 系统中如何产生一个进程
    【1】 用户空间通过调用程序接口或者命令发起请求
    【2】 操作系统接收用户请求,开始创建进程
    【3】 操作系统调配计算机资源,确定进程状态等
    【4】 操作系统将创建的进程提供给用户使用

在这里插入图片描述

  1. 进程基本概念
  • cpu时间片:如果一个进程占有cpu内核则称这个进程在cpu时间片上。

  • PCB(进程控制块):在内存中开辟的一块空间,用于存放进程的基本信息,也用于系统查找识别进程。

  • 进程ID(PID): 系统为每个进程分配的一个大于0的整数,作为进程ID。每个进程ID不重复。

    Linux查看进程ID : ps -aux

  • 父子进程 : 系统中每一个进程(除了系统初始化进程)都有唯一的父进程,可以有0个或多个子进程。父子进程关系便于进程管理。

    查看进程树: pstree

  • 进程状态

    • 三态
      就绪态 : 进程具备执行条件,等待分配cpu资源
      运行态 : 进程占有cpu时间片正在运行
      等待态 : 进程暂时停止运行,让出cpu

在这里插入图片描述

  • 五态 (在三态基础上增加新建和终止)
    新建 : 创建一个进程,获取资源的过程
    终止 : 进程结束,释放资源的过程

在这里插入图片描述

  • 状态查看命令 : ps -aux --> STAT列
  		S 等待态
  		R 执行态
  		D 等待态
  		T 等待态
  		Z 僵尸
  		<  有较高优先级
  		N  优先级较低
  		+  前台进程
  		s  会话组组长
  		l  有多线程的
  • 进程的运行特征
    【1】 进程可以使用计算机多核资源
    【2】 进程是计算机分配资源的最小单位
    【3】 进程之间的运行互不影响,各自独立
    【4】 每个进程拥有独立的空间,各自使用自己空间资源

问题:

  1. 什么是进程,进程和程序有什么区别?
  2. 进程有哪些状态,状态之间如何转化?
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值