Python并发编程01 /操作系统发展史、多进程理论
Python并发编程01 /操作系统发展史、多进程理论
1. 操作系统
定义:管理控制协调计算机中硬件与软件的关系
操作系统的作用:
第一个作用: 将一些复杂丑陋的硬件调用的接口,变成简单美丽的接口. open函数.
第二个作用: 多个进程抢占一个(CPU)资源时,操作系统会将其执行变得合理有序.操作系统的发展史
第一代计算机1940~1955
在大学里出现了机房,想使用计算机必须预约,先连接调配各个硬件,1.5小时, 真空管, 然后在插上程序调试.效率低.
优点:
个人独享整个计算机资源.
缺点:
1. 硬件调试插线,耗时
2. 所有人都是串行执行.
第二代计算机 磁带存储---批处理系统 1955~1965
优点:
1. 程序员不用亲自对硬件进行插线操控,效率提高.
2. 可以进行批量处理代码.
缺点:
1. 程序员不能独自使用计算机.
2. 你的所有程序还是串行.
第三代计算机:集成电路,多道程序系统
# 大背景:
1. 集成电路: 把所用的硬件变小,线路板.
2. 将两套不同的生产线合并成一条生产线. # 技术上的更新: 多道技术.
1. 空间上的复用:
将内存分区域,一个内存可以同时加载多个进程.
2. 时间上的复用:
实现将cpu在多个进程之间来回切换,并且保留状态. # 第三代计算机广泛采用了必须的保护硬件(程序之间的内存彼此隔离)之后,第三代计算机应用而生:多人(少于10个) 共同使用一个计算机主机,
第四代计算机: 至今.
2. 进程理论
概念
- 串行:所有的任务一个一个的完成.
- 并发:一个cpu完成多个任务.看起来像是同时完成.
- 并行:多个cpu执行多个任务,真正的同时完成.
- 阻塞:cpu遇到IO就是阻塞.
- 非阻塞:没有IO,就叫非阻塞.
- 程序:一堆静态文件
- 进程:一个正在执行的程序任务,一个程序能否开启多个进程
进程的创建
一个子进程必须依赖于一个主进程才可以开启.
一个主进程可以开启多个子进程.
unix创建进程:
unix: fork创建子进程.
unix(linux,mac): 创建一个子进程会完完全全复制一个主进程所有的资源,初始资源不变.windows创建进程:
windows: 操作系统调用CreateProcess 处理进程的创建.
windows:创建一个子进程,会copy主进程所有的资源,但是会改变一些资源.
进程的状态
运行:执行程序文件代码
阻塞:程序运行时遇到IO就是阻塞
就绪:阻塞完成后或者正在运行别的程序,可能会来不及切换回来,这之间的状态就是中间状态

Python并发编程01 /操作系统发展史、多进程理论的更多相关文章
- Python并发编程-一个简单的多进程实例
import time from multiprocessing import Process import os def func(args,args2): #传递参数到进程 print(args, ...
- Python并发编程一(多进程)
1.背景知识(进程.多道技术) 顾名思义,进程即正在执行的一个过程.进程是对正在运行程序的一个抽象. 进程的概念起源于操作系统,是操作系统最核心的概念,也是操作系统提供的最古老也是最重要的抽象概念之一 ...
- python并发编程&多进程(二)
前导理论知识见:python并发编程&多进程(一) 一 multiprocessing模块介绍 python中的多线程无法利用多核优势,如果想要充分地使用多核CPU的资源(os.cpu_cou ...
- python并发编程&多进程(一)
本篇理论居多,实际操作见: python并发编程&多进程(二) 一 什么是进程 进程:正在进行的一个过程或者说一个任务.而负责执行任务则是cpu. 举例(单核+多道,实现多个进程的并发执行) ...
- Python并发编程理论篇
Python并发编程理论篇 前言 其实关于Python的并发编程是比较难写的一章,因为涉及到的知识很复杂并且理论偏多,所以在这里我尽量的用一些非常简明的语言来尽可能的将它描述清楚,在学习之前首先要记住 ...
- Python并发编程系列之多进程(multiprocessing)
1 引言 本篇博文主要对Python中并发编程中的多进程相关内容展开详细介绍,Python进程主要在multiprocessing模块中,本博文以multiprocessing种Process类为中心 ...
- python并发编程02 /多进程、进程的创建、进程PID、join方法、进程对象属性、守护进程
python并发编程02 /多进程.进程的创建.进程PID.join方法.进程对象属性.守护进程 目录 python并发编程02 /多进程.进程的创建.进程PID.join方法.进程对象属性.守护进程 ...
- Python并发编程__多进程
Python并发编程_多进程 multiprocessing模块介绍 python中的多线程无法利用多核优势,如果想要充分地使用多核CPU的资源(os.cpu_count()查看),在python中大 ...
- Python进阶(4)_进程与线程 (python并发编程之多进程)
一.python并发编程之多进程 1.1 multiprocessing模块介绍 由于GIL的存在,python中的多线程其实并不是真正的多线程,如果想要充分地使用多核CPU的资源,在python中大 ...
随机推荐
- OpenSSH详解
OpenSSH详解(思维导图) 1. SSH概述 SSH 软件架构 认证方式 2. OpenSSH 2.1 客户端程序ssh 配置文件 ssh命令 客户端免密登录 scp sftp 2.2 服务端程序 ...
- Ultra-QuickSort (求逆序数+离散化处理)、Cows、Stars【树状数组】
一.Ultra-QuickSort(树状数组求逆序数) 题目链接(点击) Ultra-QuickSort Time Limit: 7000MS Memory Limit: 65536K Total ...
- nodejs 换源
解决npm install安装慢的问题国外镜像会很慢 可用 get命令查看registry npm config get registry 原版结果为 http://registry.npmjs.or ...
- spring Cloud网关之Spring Cloud Gateway
Spring Cloud Gateway是什么?(官网地址:https://cloud.spring.io/spring-cloud-gateway/reference/html/) Spring C ...
- 1、python简介-变量-注释-数据类型-用户交互-if语句-while循坏
一. 计算机是什么 基本组成: 主板+cpu+内存 cpu: 主频, 核数(16) 内存:大小(8G, 16G, 32G) 型号: DDR3, DDR4, DDR5, 主频(海盗船,玩家国度) 显卡: ...
- JavaWeb网上图书商城完整项目--验证码
1.首先需要集成下面的jar 2.在web.xml配置验证码的servlet <?xml version="1.0" encoding="UTF-8"?& ...
- xutils工具上传日志文件
首先下载xutils java包: 添加到项目的工程中: 第二在新建一个类继承application package logback.ecmapplication.cetcs.com.myapplic ...
- 慕课网--java权限管理系统
http://coding.imooc.com/class/evaluation/149.html
- 一条update SQL语句是如何执行的
一条更新语句的执行过程和查询语句类似,更新的流程涉及两个日志:redo log(重做日志)和binlog(归档日志).比如我们要将ID(主键)=2这一行的值加(c:字段)1,SQL语句如下: upda ...
- Oracle的number数据类型
https://www.cnblogs.com/oumyye/p/4448656.html NUMBER ( precision, scale) precision表示数字中的有效位;如果没有指定pr ...