操作系统发展史

穿孔卡片

一个计算机机房,一次只能被一个卡片使用

缺点:CPU利用率最低

联机批处理系统

支持多用户去使用一个计算机机房

脱机批处理系统

高速磁盘:

​ 提高文件的读取速度

优点:

​ 提高CPU的利用率

多道技术(基于单核情况下研究)

单道

多个使用CPU时是串行

多道技术

空间上的复用(重点)

一个CPU可以提供个多个用户去使用

时间上的复用(重点)

切换 + 保存状态

IO操作

input()

print()

time.sleep(5)

1.若CPU遇到IO操作,会立即将当前执行程序CPU使用权断开

​ 优点:

​ CPU的利用率高

2.若一个程序使用CPU的时间过长,会立即将当前程序CPU使用权断开

​ 缺点:

​ 程序的执行率降低

并发与并行

并发

指的是看起来像同时运行,多个程序不停 切换 + 保存状态。

并行

真实意义上的同时运行,在多核(多个CPU)的情况下,同时执行多个程序。

进程

程序与进程

程序:一堆代码

进程:一堆代码运行的过程

进程调度

当代操作系统调度:

​ 时间片轮转法 + 分级反馈对列

先来先服务调度

a,b程序,若a程序先来,先占用CPU

缺点:

​ 程序a先使用,程序b必须等待程序a使用CPU结束后才能使用

短作业优先调度

a,b程序,谁的用时短,先优先调度使用CPU

缺点:

​ 若程序a使用时间最长,有N个程序使用时间短,

​ 必须等待所有用时短的程序结束后才能使用。

时间片轮转法

CPU执行的时间1秒中,加载N个程序,要将1秒等分成多N个时间片。

分级反馈队列

​ 将执行优先分为多层级别

​ - 1级:优先度最高

​ - 2级:优先级第二,以此类推

​ - 3级

​ ......

进程的三个状态

就绪态

所有进程创建时都会进入的就绪态,准备调度。

运行态:

调度后的进程,进入运行态。

阻塞态

凡是遇到IO操作的进程,都会进入阻塞态,

若IO结束,必须重新进入就绪态。

同步与异步

指的是提交任务的方式

同步

若有两个任务需要提交,在提交第一个任务时,

必须等待该任务执行结束后,才能继续提交并执行第二个任务。

异步

若有两个任务需要提交,在提交第一个任务时,

不需要原地等待,立即可以提交并执行第二个任务。

阻塞与非阻塞

阻塞

阻塞态。遇到IO操作一定会阻塞

非阻塞

就绪态

运行态

面试题:同步和异步,阻塞和非阻塞是同一个概念吗?

:强调: 不是同一个概念,不能混为一谈!

进程号回收的两种条件

1.join,可以回收子进程与主进程

2.主进程正常结束,子进程与主进程也会被回收

僵尸进程与孤儿进程

僵尸进程

指的是子进程已经结束,但PID号还存在,未销毁。

缺点:

​ 占用PID号,占用操作系统资源

孤儿进程

指的是子进程还在执行,父进程意外结束

操作系统优化机制:

​ 提供一个福利院,帮你回收没有父亲的子进程。

守护进程

指的是主进程结束后,该主进程产生的所有子进程跟着结束,并回收。

day 28的更多相关文章

  1. 28个你必须知道的HTML5的新特性,技巧以及技术

    崭新新的页面布局 传统的: HTML5: 1. 新的Doctype 尽管使用<!DOCTYPE html>,即使浏览器不懂这句话也会按照标准模式去渲染 2. Figure元素 用<f ...

  2. CSharpGL(28)得到高精度可定制字形贴图的极简方法

    CSharpGL(28)得到高精度可定制字形贴图的极简方法 回顾 以前我用SharpFont实现了解析TTF文件从而获取字形贴图的功能,并最终实现了用OpenGL渲染文字. 使用SharpFont,美 ...

  3. 来,一起让我们越来越懒,面向CSS、JS未来编程。(9.28已更新)

    2016.10.29更新 本文存在大量的错误,仅供参考. 不知不觉在前端领域马上一个年头就要过去了,然而再看看自己的代码,果然够烂,那么为什么代码一直没有用面向对象的思维去写CSS呢?首先有两点:一点 ...

  4. MySQL报错:Got error 28 from storage engine

    今天碰到数据库出错: Got error 28 from storage engine 查了一下,数据库文件所在的盘应该没事,应该是数据库用的临时目录空间不够 问题原因: 磁盘临时空间不够导致. 解决 ...

  5. [.net 面向对象程序设计进阶] (28) 结束语——告别2015

    [.net 面向对象程序设计进阶] (28) 结束语——告别2015 <.net面向对象程序设计进阶>这一系列文章写了太长的时间了,大概有半年没写,在年底又一口气写了好几篇.在整个过程中目 ...

  6. 背水一战 Windows 10 (28) - 控件(文本类): TextBox, PasswordBox

    [源码下载] 背水一战 Windows 10 (28) - 控件(文本类): TextBox, PasswordBox 作者:webabcd 介绍背水一战 Windows 10 之 控件(文本类) T ...

  7. 10月28日PHP基础知识测试题

    本试题共40道选择题,10道判断题,考试时间1个半小时 一:选择题(单项选择,每题2分): 1. LAMP具体结构不包含下面哪种(A) A:Windows系统 B:Apache服务器 C:MySQL数 ...

  8. CentOS6.3编译安装Nginx1.4.7 + MySQL5.5.25a + PHP5.3.28

    [准备工作] #在编译安装lnmp之前,首先先卸载已存在的rpm包. rpm -e httpd rpm -e mysql rpm -e php yum -y remove httpd yum -y r ...

  9. 记 Mac Pro 系统升级后,编译安装 PHP-5.6.28 / PHP-7.0 报错修复过程

    买 Mac Pro 的时候,系统为 OS X 10.11.5,编译 PHP-5.6.21 的时候,也遇到一些坑,安装过程记录如下: Mac Pro 编译安装 PHP 5.6.21 及 问题汇总 后来, ...

  10. 28. 字符串的排列之第1篇[StringPermutation]

    [题目] 输入一个字符串,打印出该字符串中字符的所有排列.例如输入字符串abc,则输出由字符a.b.c所能排列出来的所有字符串abc.acb.bac.bca.cab和cba. [分析] 这是一道很好的 ...

随机推荐

  1. 洛谷p2827蚯蚓题解

    题目 算法标签里的算法什么的都不会啊 什么二叉堆?? qbxt出去学习的时候讲的,一段时间之前做的,现在才写到博客上的 维护3个队列,队列1表示最开始的蚯蚓,队列2表示每一次被切的蚯蚓被分开的较长的那 ...

  2. [TJOI2009]猜数字(洛谷 3868)

    题目描述 现有两组数字,每组k个,第一组中的数字分别为:a1,a2,...,ak表示,第二组中的数字分别用b1,b2,...,bk表示.其中第二组中的数字是两两互素的.求最小的非负整数n,满足对于任意 ...

  3. nginx虚拟机配置

    #虚拟主机的配置server {#监听端口listen 80;#服务器域名server_name localhost;#网页的默认编码#charset koi8r;#访问该虚拟主机的日志位置#acce ...

  4. failed to execute /bin/bash: Resource temporarily unavailable的问题处理

    [admin@localhost ~]$ sudo su - scloanLast login: Tue Jun 12 14:06:31 CST 2018 on pts/3su: failed to ...

  5. python 项目实战之备份文件夹并且压缩文件夹及下面的文件

    #!/usr/bin/env python # -*- coding: utf-8 -*- # @Time : 2019/11/12 14:21 # @Author : zoulixiang # @S ...

  6. concurrent (一)concurrent

    参考文档: 跳跃表原理分析:https://blog.csdn.net/a1259109679/article/details/46442895 一.阻塞队列 ArrayBlockingQueue : ...

  7. Hyperledger Fabric 1.4 快速环境搭建

    自己的硕士研究方向和区块链有关,工程上一直以IBM的Hyperledger Fabric为基础进行开发,对该项目关注也有两年了.目前迎来了Hyperledger Fabric v1.4,这也是Fabr ...

  8. libevent笔记4:Filter_bufferevent过滤器

    Filter_bufferevent是一种基于bufferevent的过滤器,其本身也是一个bufferevent.能够对底层bufferevent输入缓存区中的数据进行操作(加/解密等)后再读取,同 ...

  9. cad问题小百科 持续更新

    一些浩辰的问题移步去: 浩辰问题        (浩辰可能和桌子具有相同的问题,所以这篇你可能还是要看 cad2007遇到了这种情况 安装问题安装CAD出现C++2005问题的解决方法,出现此问题,原 ...

  10. this指北 (一篇读懂)

    this 关键字 涵义 this关键字是一个非常重要的语法点.毫不夸张地说,不理解它的含义,大部分开发任务都无法完成. 前一章已经提到,this可以用在构造函数之中,表示实例对象.除此之外,this还 ...