多任务编程

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

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

3.并行与并发

  • 并发 : 同时处理多个任务,内核在任务间不断的切换达到好像多个任务被同时执行的效果,实际每个时刻只有一个任务占有内核。
  • 并行 : 多个任务利用计算机多核资源在同时执行,此时多个任务间为并行关系。

进程(process)

进程理论基础

1.定义 : 程序在计算机中的一次运行。

  • 程序是一个可执行的文件,是静态的占有磁盘。
  • 进程是一个动态的过程描述,占有计算机运行资源,有一定的生命周期。

2.系统中如何产生一个进程

  1. 用户空间通过调用程序接口或者命令发起请求
  2. 操作系统接收用户请求,开始创建进程
  3. 操作系统调配计算机资源,确定进程状态等
  4. 操作系统将创建的进程提供给用户使用

3.进程基本概念

  • 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. 每个进程拥有独立的空间,各自使用自己空间资源

转载于:https://www.cnblogs.com/maplethefox/p/10989075.html

Python并发编程—进程相关推荐

  1. Python 并发编程--进程,线程,协程

    并发编程 基本概念的区分: 并发 只有一个CPU,多个程序在一个CPU上轮流执行,宏观上多个进程并发执行,但微观上依旧是串行 并行 有多个CPU,多个程序在多个CPU上同时执行. 进程 计算机中最小的 ...

  2. python并发编程--进程、线程、协程、锁、池、队列

    文章目录 操作系统的概念 进程 multiprocessing模块 守护进程 使用多进程实现一个并发的socket的server 锁 生产者消费者模型 数据共享 线程threading模块 守护线程和 ...

  3. python并发编程-进程池线程池-协程-I/O模型-04

    目录 进程池线程池的使用***** 进程池/线程池的创建和提交回调 验证复用池子里的线程或进程 异步回调机制 通过闭包给回调函数添加额外参数(扩展) 协程*** 概念回顾(协程这里再理一下) 如何实现 ...

  4. python 并发编程 多线程 目录

    线程理论 python 并发编程 多线程 开启线程的两种方式 python 并发编程 多线程与多进程的区别 python 并发编程 多线程 Thread对象的其他属性或方法 python 并发编程 多 ...

  5. 《转载》Python并发编程之线程池/进程池--concurrent.futures模块

    本文转载自 Python并发编程之线程池/进程池--concurrent.futures模块 一.关于concurrent.futures模块 Python标准库为我们提供了threading和mul ...

  6. 学习笔记(33):Python网络编程并发编程-进程池线程池

    立即学习:https://edu.csdn.net/course/play/24458/296451?utm_source=blogtoedu 进程池与线程池: 一般应用在网站上,进程池或线程池最大的 ...

  7. python并发编程之semaphore(信号量)_浅谈Python并发编程之进程(守护进程、锁、信号量)...

    前言:本博文是对Python并发编程之进程的知识延伸,主要讲解:守护进程.锁.信号量. 友情链接: 一.守护进程(daemon) 1.1 守护进程概念 首先我们都知道:正常情况下,主进程默认等待子进程 ...

  8. Python并发编程之线程池/进程池

    引言 Python标准库为我们提供了threading和multiprocessing模块编写相应的多线程/多进程代码,但是当项目达到一定的规模,频繁创建/销毁进程或者线程是非常消耗资源的,这个时候我 ...

  9. Python并发编程之进程池

    Python并发编程之进程池 一.进程池简介 二.进程池代码实例 一.进程池简介 可以用Pool类来创建进程池,可以把各种数据处理任务都提交给进程池.进程池提供的功能有点类似于列表解析和功能性编程操作 ...

最新文章

  1. Django annotate: 外键字段解析问题
  2. python中组合与继承的区别_python类与对象的组合与继承
  3. 计算机专业理论,计算机专业综合理论.doc
  4. vscode gcc debug dbg gdb c cpp c++ cuckoo monitor
  5. php header 文件大小,php获取远程文件大小及信息的函数(head_php
  6. 如何复制图文消息封面图片?正文没显示
  7. 大V诞生记 —— 谁是VMware?
  8. virtualmin修改php.ini,virtualmin安装和配置使用
  9. EF中DataContext创建的两段代码收藏
  10. NBU官方Doc網址https://www.veritas.com/support/en_US/article.DOC5332
  11. python输出图片字体加粗_python中xticks字体加粗-女性时尚流行美容健康娱乐mv-ida网...
  12. iOS - iOS8.0 至 iOS15.0 版本变化
  13. 计算机桌面上的照片转pdf免费,电脑上怎样快速将图片转PDF
  14. Python:摄氏温度转华氏温度
  15. charles+安卓模拟器采集豆果美食app
  16. 外媒点赞,浪潮存储为何能入围全球最佳主存储供应商
  17. 波卡的盔甲与弱肋 |链捕手
  18. 电脑族科学护眼五常识
  19. 微信公众号身份证OCR识别和验真|人证比对
  20. 『Java安全』Tomcat内存马_动态注册Listener内存马

热门文章

  1. 关于 命令行参数 main(int argc,char** argv)
  2. web压力测试之siege
  3. 分类算法——决策树算法及其R实现
  4. 欠条和借条傻傻分不清?小心借出的钱要不回!
  5. 为什么别人有微粒贷,而你没有?
  6. netlink怎么读_内核交互 netlink,检测部分进程死亡和启动。
  7. java jar 环境变量_java-jar jar包带环境变量(参数)启动
  8. python怎么引用多行输入_python调用shell返回两行第二行需要输入密码怎么办?import os os.syst...
  9. zend optimizer php5.5,PHP_PHP5.3以上版本安装ZendOptimizer扩展,现在很多PHP程序都需要ZendOptimi - phpStudy...
  10. 利用matlab提取中心线