1、操作系统四特性

  1. 并发:一个时间段,多个进程在宏观上同时运行
  2. 共享:系统中的资源可以被多个并发进程共同使用(互斥共享,同时共享)
  3. 虚拟:利用多道程序设计,利用时分复用(分时系统)和空分复用(虚拟内存),使得一台物理设备在感觉上像是多台物理设备
  4. 异步:程序的执行不是一贯到底,而是走走停停,向前推进的速度是不可预知的

2、用户态和核心态

references:内核态和用户态

概念

用户态:用户态具有较低的权限(3环),运行在用户态的程序不能直接访问内核中的程序和数据结构。大部分用户面对的程序都是在用户态的,只能执行非特权指令。

内核态:具有较高的权限(0环),可以访问内存中所有的数据包括外围设备,能执行特权指令。sys_fork()就运行在内核态。

RING0~RING3的权限分级是通过硬件实现的。

每个进程中有两个栈:用户栈和内核栈。分别对应用户态和内核态。

用户态到内核态的切换

用户态切换到内核态的三种方式:系统调用,异常,外围设备的中断

  1. 系统调用:用户态进程主动要求切换到内核态的方式,用户态进程通过系统调用来申请操作系统提供的服务。比如fork()创建新的进程。
  2. 异常:CPU在执行用户态程序时发生了异常,就会切换到处理此异常的相关内核程序。比如缺页异常。
  3. 外围设备的中断:外围设备完成用户请求的操作后,会向CPU发送相应的中断信号,那么CPU就会暂停下一条指令,然后去执行中断信号所指的程序。比如硬盘读写完成,

为什么要分用户态和内核态

CPU将指令分为特权指令和非特权指令。特权指令权限非常大(清内存、修改用户的访问权限),使用不当将导致程序崩溃,如果所有程序都能使用特权指令,那么这是很危险的。

3、缓冲区

references:缓冲区

概念

缓冲区是内存空间的一部分,即内存中预留了一定的存储空间,用来缓冲输入输出数据。

为什么引入缓冲区

高速设备和低速设备的速度不匹配,会让高速设备等待低速设备。

作用:

  1. 解除两者制约关系,高速设备把数据输入缓冲区就可以去处理别的事情,低速设备从缓冲区读取数据。
  2. 减少数据读写次数,如果每次传输的数据很少,那么传输的次数就要增加。如果使用缓冲区,待缓冲区满后再读出,次数就减少了。

分类

全缓冲:缓冲区填满时才调用IO操作。磁盘文件通常是全缓冲。

行缓冲:遇到'\n'换行符才调用IO操作,但是缓冲区满了没遇到'\n'也会调用IO操作。如命令行输入。

无缓冲:不进行缓冲。有的时候我们希望数据第一时间显示出来,比如显示错误信息stderr(标准错误)。

缓冲区的刷新

  • 缓冲区满
  • 关闭文件
  • C++中提供了flush

缓冲区刷新时,会进行IO操作把数据读出

缓冲区溢出

计算机向缓冲区填充数据时超过了缓冲区本身的容量,溢出的数据覆盖到了合法数据上。

原因:没有检查用户输入的合法性。

4、协程

协程,又叫微线程,是一种用户态的“线程”,其实是一种函数。

线程、进程都是内核管理创建销毁等等,但是协程完全由程序控制,完全由程序员来调度,所以协程都在用户态下。线程、进程在多核情况下能进行并行,但是协程不行。

优点

  1. 协程的切换开销很小,和内核没有关系,也不需要同步机制。
  2. 单线程内就能实现高并发的效果。

缺点

  1. 协程无法利用多核资源。
  2. 协程阻塞将导致整个线程阻塞。

在Python中,可以使用yield/send来使用协程。

协程执行到yield会阻塞,然后等待send进来一个东西再继续执行

def consumer():
print("开始吃")
while True:
str = yield
print("吃了" + str) if __name__ == '__main__':
con = consumer() #消费者对象
next(con)
food = ["西瓜", "蛋糕", "馒头"]
for i in food:
print("生产了" + i)
con.send(i)
# 输出:
开始吃
生产了西瓜
吃了西瓜
生产了蛋糕
吃了蛋糕
生产了馒头
吃了馒头

操作系统 part3的更多相关文章

  1. 秋招C++面试相关总结索引

    C++相关 C++ part1 C++ part2 C++ part3 C++ part4 C++ part5 C++ part6 C++ part6.5 C++ part7 C++ part8 C+ ...

  2. Linux内核分析——操作系统是如何工作的

    万子惠 + 原创作品转载请注明出处 + <Linux内核分析> 实验部分 使用实验楼的虚拟机打开shell 然后cd mykernel 您可以看到qemu窗口输出的内容的代码mymain. ...

  3. [自制操作系统] BMP格式文件读取&图形界面系统框架/应用接口设计

    本文将介绍在本人JOS中实现的简单图形界面应用程序接口,应用程序启动器,以及一些利用了图形界面的示例应用程序. 本文主要涉及以下部分: 内核/用户RW/RW调色板framebuffer共享区域 8bi ...

  4. 30天自制操作系统day2汇编语言

    <30天自制操作系统>一书中第1天和第二天中有关汇编语言的程序的理解 ; hello-os ; TAB=4 ORG 0x7c00 ; 指明程序的装载地址 ; 以下的记述用于标准FAT12格 ...

  5. 操作系统篇-调用门与特权级(CPL、DPL和RPL)

    || 版权声明:本文为博主原创文章,未经博主允许不得转载. 一.前言 在前两篇文章(<操作系统篇-浅谈实模式与保护模式>和<操作系统篇-分段机制与GDT|LDT>)中,我们提到 ...

  6. Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part3:db安装和升级

    Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part3:db安装和升级 环境:OEL 5.7 + Oracle 10.2.0.5 RAC 5.安装Database软件 5. ...

  7. 操作系统篇-分段机制与GDT|LDT

    || 版权声明:本文为博主原创文章,未经博主允许不得转载. 一.前言     在<操作系统篇-浅谈实模式与保护模式>中提到了两种模式,我们说在操作系统中,其实大部分时间是待在保护模式中的. ...

  8. 操作系统篇-hello world(免系统运行程序)

     || 版权声明:本文为博主原创文章,未经博主允许不得转载. 一.前言     今天起开始分享关于操作系统的相关知识,本人也是菜鸟一个,正处于学习阶段,这整个操作系统篇也是我边学习边总结的一些结果,希 ...

  9. Linux实战教学笔记03:操作系统发展历程及系统版本选择

    标签(空格分隔): Linux实战教学笔记-陈思齐 第1章 Linux简介 1.1 什么是操作系统? 简单讲:操作系统就是一个人与计算机硬件的中介. 操作系统,英文名称Operating System ...

随机推荐

  1. zabbix-server安装部署配置

    zabbix-server安装部署配置 zabbixLinux安装部署安装脚本 1 一步一步部署 1.1 安装zabbix仓库源 这里安装阿里的zabbix仓库地址 选用zabbix版本3.4 rpm ...

  2. Percona Toolkit工具使用

    Percona Toolkit简称pt工具-PT-Tools,是Percona公司开发用于管理MySQL的工具,功能包括检查主从复制的数据一致性.检查重复索引.定位IO占用高的表文件.在线DDL等 下 ...

  3. C#高级编程第11版 - 第二章 索引

    [1]2.1.1 Hello,World! 1. using static System.Console; // ... WriteLine("Hello World!"); 提前 ...

  4. javascript之Banner图片焦点轮播

    这个Banner唯一不好的就是没有前进和后退的button,写过两个版本的banner,这次这个是下面有浮动层的. <!DOCTYPE html><html xmlns=" ...

  5. Java并发包源码学习系列:阻塞队列实现之DelayQueue源码解析

    目录 DelayQueue概述 类图及重要字段 Delayed接口 Delayed元素案例 构造器 put take first = null 有什么用 总结 参考阅读 系列传送门: Java并发包源 ...

  6. 利用burp抓取https的包

    本片文章仅供学习使用,切勿触犯法律! 0x01.打开burp的代理监听器 0x02.使用代理访问 这里我是用的是mantra,其他浏览器同理. 0x03.浏览器输入http://burp 点击CA C ...

  7. Java Web学习之路

    编程基础 1-1 常用数据结构 数组.链表.堆.栈.队列.Hash表.二叉树等1-2 算法思想 算法时间复杂度和空间复杂度的分析计算 1-2 算法思想:递推.递归.穷举.贪心.分治.动态规划.迭代.分 ...

  8. Prometheus 初探和配置(安装测试)

    本文大纲: • Prometheus 官⽹下载• Prometheus 开始安装• Prometheus 启动运⾏• Prometheus 基本配置⽂件讲解• 安装第⼀个exporter => ...

  9. Spark使用Java、Scala 读取mysql、json、csv数据以及写入操作

    Spark使用Java读取mysql数据和保存数据到mysql 一.pom.xml 二.spark代码 2.1 Java方式 2.2 Scala方式 三.写入数据到mysql中 四.DataFrame ...

  10. SparkStreaming算子操作,Output操作

    SparkStreaming练习之StreamingTest,UpdateStateByKey,WindowOperator 一.SparkStreaming算子操作 1.1 foreachRDD 1 ...