当前位置: 首页 > news >正文

操作系统(笔记)(一)

1、操作系统的功能和目标

1.1功能

  • 存储管理
  • 文件管理
  • 设备管理
  • 处理机管理
  • 进程管理

1.2目标

  • 方便性:操作系统作为用户与计算机硬件系统之间的接口,提供了直观的命令和界面,使得用户能够更容易地操作计算机。
  • 有效性:操作系统旨在提高系统资源的利用率,通过合理组织计算机的工作流程,加速程序的运行,缩短程序的运行周期,从而提高系统的吞吐量。
  • 可扩充性:为了适应计算机硬件、体系结构以及应用程序的发展,操作系统需要具有良好的可扩充性,以便于添加、修改相应的功能和模块。
  • 开放性:在计算机应用的日益普及和网络环境的转向下,操作系统的开放性变得尤为重要,以便于不同硬件和软件之间的兼容。

直接给用户使用:

  • GUI(图形用户界面)
  • 命令接口
    • 联机命令接口
    • 脱机命令接口

给软件程序员使用:

  • 程序接口

其中命令接口和程序接口统称为“用户接口”

2、操作系统的特征

2.1并发

指的是在一个时间段内,有多任务或多线程在交替执行。在这种情况下,多个任务或线程可能会同时占用CPU资源,但在宏观层面上,它们的执行是按照一定的顺序进行的。并发提高了系统的资源利用率和吞吐量,因为它允许多个任务在不完全同时执行的情况下相互竞争CPU的使用权。并发通常涉及到任务调度和时间片轮询等技术来实现对CPU资源的合理分配。(宏观上同时发生,微观上交替发生

例子:这就比如一天上午,我8:00-10:00需要学习操作系统,10:00-12:00需要学习数据库,在“一天上午”的角度上看,我这一天上午同时学习了操作系统和数据库,而从“小时”的角度上看,我是交替学习这两门课程的。

注意:单核CPU同一时刻只能执行一个程序,各个程序只能并发进行

           多核CPU同一时刻可以执行多个程序,各程序可以并发进行

2.2并行

则意味着在同一时间段内,多个任务或线程同时在不同的处理器核心上执行。并行计算能够充分利用所有可用的硬件资源,因为它允许多个任务并行运行而不必等待其他任务完成。并行计算可以提高系统的性能和效率,特别是在处理大数据集、图形渲染和其他需要大量计算的任务时。并行可以通过多处理器系统或分布式计算架构实现。

例子:我在学习时,同时学习操作系统和数据库,即在同一时刻,我的脑子里面既是操作系统的知识,又是数据库的知识。

2.3共享

2.3.2互斥共享

某些资源在同一时刻只能被一个进程访问。

2.3.2同时访问共享

允许多个进程在同一时刻访问同一个资源

并发性和共享性互为存在条件。

2.4虚拟

  • 空分虚拟技术
  • 时分虚拟技术

2.5异步

多个程序并发运行的环境中,每个程序的运行结果、运行次序以及每次运行的时间都是不确定的

只有并发性才会导致异步性

3、操作系统运行机制

特权指令:只能由操作系统使用的指令

支持多道程序运行要区分为特权指令和非特权指令

特权指令一般引起处理器状态的切换

3.1内核态(管态)

操作系统管理程序运行的状态,较高的特 权级别,又称特权态(特态)、内核态、系统态。能够执行所有指令,使用所有资源,改变CPU状态

3.2用户态(目态)

用户程序运行时的状态,较低的特权级别, 又称为普通态(普态)、用户态,只能执行非特权指令

注意:程序状态寄存器(PSW),有一个二进制位用来判断系统处于哪一个状态。

3.3状态转变

3.3.1程序状态寄存器/程序状态字(PSW)

CF: 进位标志位     

ZF: 结果为零标志位     

SF: 符号标志位       

OF: 溢出标志位

TF:陷阱标志位

IF:中断允许(中断屏蔽)标志位

VIF:虚拟中断标志位

VIP:虚拟中断待决标志位

IOPL:IO特权级别

3.3.2管态->目态

执行一条特权指令修改PSW

3.3.3目态->管态

由中断引起,硬件自动完成

系统调用

4.中断

4.1内中断(也称为异常)

注意上图中管态下执行的指令可以使“特权指令”也可以是“非特权指令”,也就是说管态可以执行计算机所有指令

实例1:试图在目态下执行特权指令

实例2:执行除法时发现除数为0

实例3:有时应用程序想请求操作系统内核的服务

此时会执行陷入指令(trap指令)———会引发一个内部中断信号。注意陷入指令是不是特权指令(因为目态可以正常执行)

4.1.1陷入

此情况是应用程序故意引发的(即一个程序执行,需要用到特权指令,这时非特权指令会执行trap指令,使CPU状态进入管态,执行需要的指令。此从目态到管态的过程,需要执行的非特权指令成为陷入指令,这个过程成为陷入。)

4.1.2故障

由错误条件引起,可能被内核程序修复,修复后内核会把CPU使用权还给应用程序,继续执行下面的指令。

4.1.3中止

由致命错误引起,内核无法修复,一般不会再把CPU使用权还给应用程序,而是直接中止此程序

4.2外中断(狭义地称为中断)

时钟部件每隔一段时间给CPU发送一个中断信号。而且需要时I/O设备也会给CPU发送中断信号。

4.3中断机制的原理

对于不同的中断信号,需要不同的中断处理程序来处理。当CPU检测到中断信号后,会根据中断信号的类型去查询“中断向量表”,以此来找到中断处理程序在内存中存放的位置。

注意:由上面可知,中断处理程序应该是内核程序(需要运行在内核态)

5计算机组织结构

5.1  I/O设备

计算机中的I/O设备指的是计算机与外部进行信息交换的输入、输出设备。

5.1.1输入设备

  • 负责将外部的信号经过判别、筛选和编码转换,输入到计 算机中.
  • 鼠标、键盘、扫描仪…

5.1.2输出设备

  • 将计算机内部信号经过转换,输出到外部介质上
  • 打印机、显示器…

5.1.3I/O访问方式

  • 程序控制I/O访问
    • 用程序控制I/O设备的运行:检测I/O状态、接受发送指令、 传送数据等。(结构简单、执行效率低---没有中断)
  • 中断驱动I/O访问
    • 1)CPU初始化I/O并启动第一次I/O操作。
    • 2)CPU去忙别的事情。
    • 3)当I/O完成时,CPU将被中断。
    • 4)CPU处理中断。
    • 5)CPU恢复被中断的程序。
  • 直接I/O访问
    • DMA方式

6.OS与用户之间的接口

6.1普通用户接口(Shell

  • 图形用户接口
  • 命令接口

6.2程序接口(系统调用和API)

  • 系统调用(System Call):提供进程与OS之 间的接口。
  • 应用程序接口(API):在函数的实现中封装 了系统调用。

7演化过程

  • 初步操作系统---单道批处理系统
    • 自动性
    • 顺序性
    • 单道性
  • 多道操作系统(在一段时间内,有多个程序同时占有CPU的使用权)
    • 多个作业并发批处理运行,在程序执行过程中不能与人进行交互
    • 并发性
    • 不交互性
    • 自动批处理
  • 分时操作系统系统
    • 并发运行的每个程序进程分配 一定的“时间片”(时间段)
    • 当一个程序进程在CPU中运行完 这段时间后,它就被剥夺CPU的 使用权,分时系统调度其它的程 序进程到CPU中并运行
    • 多路性(并发性)
    • 及时性
    • 交互性
    •  独立性
    • 实现共享主机
  • 个人操作系统
    • 芯片集成度越来越高,速度越来越快,价格越来越便宜
    • 16位 —> 64位
    • Windows,Linux,Minix,UNIX,Mac
    • 操作简单、界面丰富、可操作性强

例题:多道操作系统是如何让多个作业并发执行的?

  • 磁盘中管理多个程序文件,能够进行程序的读入、读出 (文件管理系统)
  • 为多个并发程序在内存中分配空间(内存管理)
  • 在一个时间段让哪个程序运行,被中断的程序如何恢复运 行(处理器管理-进程管理)
  • 为程序使用I/O设备提供方便的系统接口(I/O设备管理)

相关文章:

操作系统(笔记)(一)

1、操作系统的功能和目标 1.1功能 存储管理文件管理设备管理处理机管理进程管理 1.2目标 方便性:操作系统作为用户与计算机硬件系统之间的接口,提供了直观的命令和界面,使得用户能够更容易地操作计算机。有效性:操作系统旨在提…...

Redis线程模型解析

引言 Redis是一个高性能的键值对(key-value)内存数据库,以其卓越的读写速度和灵活的数据类型而广受欢迎。在Redis 6.0之前的版本中,它采用的是一种独特的单线程模型来处理客户端的请求。尽管单线程在概念上似乎限制了其扩展性和并…...

ros2 launch如何控制node的启动顺序

ros2 launch如何控制node的启动顺序 文章目录 引言如何写launch文件启动流程图具体launch代码总结引言 本文用来说明如何控制ros2 launch 节点的先后顺序,我们有时候需要一个节点启动完成后再启动其它节点,实现这个功能有两种方式: 在launch.py时写event根据事件触发使用li…...

Android13 framework层添加关机接口

framework层修改: t0_sys/frameworks/base/core/api/current.txt method RequiresPermission(android.Manifest.permission.REBOOT) public void reboot(Nullable String);method public void rebootp();t0_sys/frameworks/base/core/java/android/os/IPowerManager…...

GDB调试入门笔记

文章目录 What?WhyHow安装GDB安装命令查看是否安装成功调试简单的程序预备一个程序调试 使用breakinfolistnextprintstep一些小技巧在gdb前shell日志功能watch point| catch point 调试core调试一个运行的程序 What? GDB是什么? 全称GNU sym…...

JavaScript的`call`方法:实现函数间的调用!

🤍 前端开发工程师、技术日更博主、已过CET6 🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 🍚 蓝桥云课签约作者、上架课程《Vue.js 和 E…...

qt5-入门-使用拖动方式创建Dialog

参考: C GUI Programming with Qt 4, Second Edition 本地环境: win10专业版,64位,Qt5.12 目录 实现效果基本流程逐步实操1)创建和初始化子部件2)把子部件放进布局中3)设置tab顺序4&#xff09…...

【Redis】RedisTemplate和StringRedisTemplate的区别

两者的关系是 StringRedisTemplate 继承 RedisTemplate 。 两者的数据是不共通的:也就是说 StringRedisTemplate 只能管理 StringRedisTemplate 里面的数据,RedisTemplate 只能管理 RedisTemplate 中的数据。 RedisTemplate 看这个类的名字后缀是 Temp…...

面试经典150题(101-104)

leetcode 150道题 计划花两个月时候刷完之未完成后转,今天(第1天)完成了4道(101-104)150: 101.(215. 数组中的第K个最大元素) 题目描述: 给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。 请…...

Java实现读取转码写入ES构建检索PDF等文档全栈流程

背景 之前已简单使用ES及Kibana和在线转Base64工具实现了检索文档的demo,并已实现WebHook的搭建和触发流程接口。 传送门: 基于GitBucket的Hook构建ES检索PDF等文档全栈方案 使用ES检索PDF、word等文档快速开始 实现读取本地文件入库ES 总体思路&…...

主流开发环境和开发语言介绍

主流开发环境和开发语言介绍 一、主流开发环境介绍 主流开发环境是指广泛应用于软件开发的集成开发环境(Integrated Development Environment,简称IDE)。IDE是一种集成了编辑器、编译器、调试器等工具的软件,提供了一站式的开发环…...

C++ 使用 nlohmann::json存储json文件

C 使用 nlohmann::json存储json文件 nlohmann::json 概述JSON 存储的示例以追加的方式存储json文件 nlohmann::json 概述 nlohmann::json 是 C 中一个流行的 JSON 库,由 Niels Lohmann 开发。它提供了一个简单而强大的 API,用于解析、构建、操作和序列化…...

何为OOM(Out of Memory)?

OOM(Out of Memory) 是指程序运行过程中内存不足的情况。在 Spark 应用程序中,OOM 是一个非常常见的问题,尤其是在处理大规模数据集或执行资源密集型的操作时。当 Spark 作业尝试使用的内存超过了为其分配的内存限制时&#xff0c…...

SpringBoot+Mybatis-plus+shardingsphere实现分库分表

SpringBootMybatis-plusshardingsphere实现分库分表 文章目录 SpringBootMybatis-plusshardingsphere实现分库分表介绍引入依赖yaml配置DDL准备数据库ds0数据库ds1 entitycotrollerserviceMapper启动类测试添加修改查询删除 总结 介绍 实现亿级数据量分库分表的项目是一个挑战…...

FPGA DDR3简介及时序

一,DDR3基础知识 1、DDR3全称第三代双倍速率同步动态随机存储器。 特点:①掉电无法保存数据,需要周期性的刷新。 ②时钟上升沿和下降沿都会传输数据。 ③突发传输,突发长度Burst Length一般为8 2、DDR3的存储: bank、行地址和列地址 数据怎么存入到D…...

java网络编程 02 socket

01.socket定义 02.TCP编程 import java.io.IOException; import java.io.OutputStream; import java.net.InetAddress; import java.net.Socket;public class clientSocket {public static void main(String[] args) throws IOException {Socket socket new Socket(Ine…...

【Web安全】SQL各类注入与绕过

【Web安全】SQL各类注入与绕过 【Web安全靶场】sqli-labs-master 1-20 BASIC-Injection 【Web安全靶场】sqli-labs-master 21-37 Advanced-Injection 【Web安全靶场】sqli-labs-master 38-53 Stacked-Injections 【Web安全靶场】sqli-labs-master 54-65 Challenges 与62关二…...

C++ 设计模式

文章目录 类图泛化实现关联聚合组合依赖总结 类内部的三种权限(公有、保护、私有)类的三种继承方式描述与图总结 面向对象七大原则单一职责原则(Single Responsibility Principle)里氏替换原则(Liskov Substitution Pr…...

安卓使用ExoPlayer出现膨胀类异常

1.导包 implementation com.google.android.exoplayer:exoplayer-core:2.15.1implementation com.google.android.exoplayer:exoplayer-ui:2.15.1 2.在Androidifest.xml加入权限&#xff0c;我这里加了网络与读写权限 <uses-permission android:name"android.permissio…...

C++之析构函数

在 C 中&#xff0c;析构函数&#xff08;Destructor&#xff09;是一个特殊的成员函数&#xff0c;用于在对象生命周期结束时执行清理工作和资源释放。析构函数的名称与类名相同&#xff0c;前面加上波浪号&#xff08;~&#xff09;&#xff0c;不接受任何参数&#xff0c;也…...

web vue 项目 Docker化部署

Web 项目 Docker 化部署详细教程 目录 Web 项目 Docker 化部署概述Dockerfile 详解 构建阶段生产阶段 构建和运行 Docker 镜像 1. Web 项目 Docker 化部署概述 Docker 化部署的主要步骤分为以下几个阶段&#xff1a; 构建阶段&#xff08;Build Stage&#xff09;&#xff1a…...

【Go】3、Go语言进阶与依赖管理

前言 本系列文章参考自稀土掘金上的 【字节内部课】公开课&#xff0c;做自我学习总结整理。 Go语言并发编程 Go语言原生支持并发编程&#xff0c;它的核心机制是 Goroutine 协程、Channel 通道&#xff0c;并基于CSP&#xff08;Communicating Sequential Processes&#xff0…...

现代密码学 | 椭圆曲线密码学—附py代码

Elliptic Curve Cryptography 椭圆曲线密码学&#xff08;ECC&#xff09;是一种基于有限域上椭圆曲线数学特性的公钥加密技术。其核心原理涉及椭圆曲线的代数性质、离散对数问题以及有限域上的运算。 椭圆曲线密码学是多种数字签名算法的基础&#xff0c;例如椭圆曲线数字签…...

计算机基础知识解析:从应用到架构的全面拆解

目录 前言 1、 计算机的应用领域&#xff1a;无处不在的数字助手 2、 计算机的进化史&#xff1a;从算盘到量子计算 3、计算机的分类&#xff1a;不止 “台式机和笔记本” 4、计算机的组件&#xff1a;硬件与软件的协同 4.1 硬件&#xff1a;五大核心部件 4.2 软件&#…...

打手机检测算法AI智能分析网关V4守护公共/工业/医疗等多场景安全应用

一、方案背景​ 在现代生产与生活场景中&#xff0c;如工厂高危作业区、医院手术室、公共场景等&#xff0c;人员违规打手机的行为潜藏着巨大风险。传统依靠人工巡查的监管方式&#xff0c;存在效率低、覆盖面不足、判断主观性强等问题&#xff0c;难以满足对人员打手机行为精…...

比较数据迁移后MySQL数据库和OceanBase数据仓库中的表

设计一个MySQL数据库和OceanBase数据仓库的表数据比较的详细程序流程,两张表是相同的结构,都有整型主键id字段,需要每次从数据库分批取得2000条数据,用于比较,比较操作的同时可以再取2000条数据,等上一次比较完成之后,开始比较,直到比较完所有的数据。比较操作需要比较…...

深入理解Optional:处理空指针异常

1. 使用Optional处理可能为空的集合 在Java开发中&#xff0c;集合判空是一个常见但容易出错的场景。传统方式虽然可行&#xff0c;但存在一些潜在问题&#xff1a; // 传统判空方式 if (!CollectionUtils.isEmpty(userInfoList)) {for (UserInfo userInfo : userInfoList) {…...

Spring AI Chat Memory 实战指南:Local 与 JDBC 存储集成

一个面向 Java 开发者的 Sring-Ai 示例工程项目&#xff0c;该项目是一个 Spring AI 快速入门的样例工程项目&#xff0c;旨在通过一些小的案例展示 Spring AI 框架的核心功能和使用方法。 项目采用模块化设计&#xff0c;每个模块都专注于特定的功能领域&#xff0c;便于学习和…...

第八部分:阶段项目 6:构建 React 前端应用

现在&#xff0c;是时候将你学到的 React 基础知识付诸实践&#xff0c;构建一个简单的前端应用来模拟与后端 API 的交互了。在这个阶段&#xff0c;你可以先使用模拟数据&#xff0c;或者如果你的后端 API&#xff08;阶段项目 5&#xff09;已经搭建好&#xff0c;可以直接连…...

PydanticAI快速入门示例

参考链接&#xff1a;https://ai.pydantic.dev/#why-use-pydanticai 示例代码 from pydantic_ai import Agent from pydantic_ai.models.openai import OpenAIModel from pydantic_ai.providers.openai import OpenAIProvider# 配置使用阿里云通义千问模型 model OpenAIMode…...