2021-06-25

操作系统笔记
内中断 非法op 地址越界 算数溢出 缺页 陷入指令
外中断 i/o操作 时钟中断
发生中断 用户态->核心态
手工操作阶段-批道处理阶段-分时-实时-网络和分布式-个人计算机
特征:并发 共享 虚拟 异步

进程管理
多道程序 失去封闭性:不同速度的执行结果不同 间断性 不可再现性
进程实体: 程序段 数据段 pcb
特征: 动态 并发 独立 异步
进程调度 决策行为 资源分配给哪个进程
进程切换 执行行为 实际分配
先调度再切换
运行-阻塞(事件等待) 主动行为
阻塞-就绪 (时间发生)被动行为
低级通信 pv操作
高级通信
共享存储 读写操作-使用pv操作实现同步互斥
消息传递 格式化消息-发送 接收原语
管道 共享文件 半双工
线程 用户级 内核级
多线程 多对一 一对一 多对多
系统吞吐率:单位时间内cpu完成作业的数量
周转时间 完成-提交
带权周转 周转/运行
高响应比 等待+要求服务/要求服务时间
优先级 io型>计算型进程
临界资源:可共享资源,但一次只允许一个进程使用
临界区:访问临界资源的那段代码
‌禁止两个进程同时进入临界区,同步机制应遵循: 空闲让进 忙则等待 有限等待 让权等待
‌实现临界区互斥:软件实现法
单标志法 违背空闲让进
双标志法先检查 违背忙则等待
双标志法后检查 违背有限等待和空闲让进
peterson’s Algorithm 违背让权等待
硬件实现法: 中断屏蔽 硬件指令(testandset,swap)
信号量:解决同步互斥问题
被wait(s) signal(s)访问记做p v 操作
管程
条件变量:阻塞原因
对条件变量的两种操作
x.wait
x.signal
与信号量不同点:条件变量没有值仅实现排队等待,而信号量有值,反映剩余资源数
可重入代码(纯代码)允许多个进程同时访问的代码,这样的代码不能被任何进程修改
‌死锁预防 破坏 互斥 不可剥夺 请求并保持 循环等待
死锁避免 安全性 银行家算法
allocation need work
死锁检测 资源分配图 圆是进程 框是资源
死锁定理:资源分配图能否化简判断是否死锁
🔒
死锁解除 资源剥夺法 撤销进程 进程回退法

内存管理
用户程序变成可在内存中执行的程序
编译 链接 (形成逻辑地址)装入
链接方式:静态 装入时动态 运行时动态
内存的装入模块装入内存时的方式:
绝对装入 静态重定位(装入时) 动态重定位(执行时)
地址重定位:逻辑地址转换成物理地址
内存保护 界地址寄存器 寄存器的值与逻辑地址比较
重定位寄存器 逻辑地址加寄存器的值
固定分区 内部碎片
动态分区(装入内存时根据进程大小动态建立分区) 外部碎片-紧凑技术解决
‌分配策略 首次适应 地址递增
最佳适应 容量递增
最坏适应 容量递减
邻近适应 首次适应演变而成 不同在于从上次查找结束的位置继续查找
非连续分配
‌基本分页 页面大小固定 从计算机角度考虑 提高内存利用率
页表项 (页号+块号)和地址结构(页号+页内偏移) 块号+页内偏移=物理地址
页表长度 一共有多少页
页表项长度 页地址占的存储空间
页面大小 一个页面占的存储空间,加快转换速度
快表-存放当前访问的若干页表项
顶级页表 最多只能占一个页面
页号(p=a/l) 页内偏移(a%l)a是逻辑地址 l是页面大小
p与m比较 m是页表长度
页表项地址=页表始址f+页号页表项长度
页表项内容即物理块号b
物理地址e=b
l+w w页内偏移
‌基本分段 按照用户进程中的自然段划分 从用户和程序员角度考虑 方便编程 信息保护和共享 动态增长 动态链接
段号s与m比较 m是段表长度
段表项地址=段表始址f +段号*段表项长度
w段内偏移与段长比较 段长为段表项前几位
物理地址e=b+w
‌段页式 先分段 段内再分页 一个进程中 段表只有一个 ,页表可多个
传统内存管理 一次性 驻留性
虚拟内存管理 多次性 对换性 虚拟性(采用离散分配)
‌请求分页 增加请求调页和页面置换功能
最佳置换(无法实现 向后看)
先进先出 (belady现象: 分配物理块多 缺页次数不减反增)
最近最久未使用(向前看)
时钟置换算法 增加使用位,修改位
驻留集:给一个进程分配的物理页框的集合
‌页面分配策略
固定分配局部置换 为每个进程分配的物理块运行时间不改变 缺页:从进程在内存中的页面选出一页换出
可变分配全局置换 缺页:从空闲物理块队列选出一块分配
可变分配局部置换 缺页:从内存中的页面选一页换出 频繁缺页:再分配若干物理块 缺页率降低:适当减少物理块
‌调入时机:预调页 (运行前) 请求调页(运行中)
一般情况,两种策略会同时使用
‌何处调入
文件区离散分配(存放文件)
对换区连续分配(存放对换页面)
系统有足够的对换区 全部从对换区调入(文件区的文件在运行前复制到对换区)
系统缺钱少足够的对换区 不会修改的文件从文件区调入,(换出页面时若未被修改不必换出 ,若修改调到对换区)以后需要时从对换区调入(读的速度比写的速度快)
unix方式 与进程有关的文件都放在文件区 未运行的从文件区调入 运行过被换出放在对换区 下次从对换区调入 若进程请求的共享页面被其它进程调入 则无需再从对换区调入
抖动 (频繁发生缺页中断)
工作集:在某段时间间隔内,进程要访问的页面集合
<物理块数(驻留集)
<工作集窗口 时刻往前数

文件管理
单级目录:实现按名存取
两级目录:解决重名问题
树形目录:方便文件分类,有效进行文件管理和保护
无环图目录:实现文件共享
n条记录的顺序文件,平均查找n/2次
采用索引结构,查找√n次
‌静态共享方式 :
基于索引结点(硬链接) ,多个指针指向一个索引节点,保证还有一个指针指向索引结点,索引结点就不能删除
基于符号链(软链接),记录到达共享文件的路径,要访问文件时,根据路径寻找文件
文件保护:口令保护 加密保护 访问控制
‌文件系统层次
1.用户调用接口
2.文件目录系统
3.存取控制验证模块
4.逻辑文件系统与文件信息缓冲区
5.物理文件系统
6.辅助分配模块
设备管理程序模块
文件逻辑结构:从用户观点看到的文件组织形式
物理结构:从实现观点看到的文件在外存上的组织形式

文件分配方式: 连续分配(产生外部碎片)
链接分配(隐式显式) 索引分配
文件存储管理:空闲表法 空闲链表法
位示图法 成组链接法

磁盘调度算法:决定寻道时间
FCFS
最短寻找时间优先(SSTF)
扫描算法(SCAN):电梯调度返回12→9→2
循环扫描(C-SCAN):返回到最低12→2→9

簇: 由若干扇区组成
数据传输率: 数据量/时间
磁带利用率:利用磁带/总磁带

I/O管理
i/o控制方式:
程序直接控制方式 :cpu要不断测试io设备状态
中断驱动方式 :数据交换经过cpu寄存器
DMA方式 :传送开始和结束时需要cpu,传送由DMA控制器()完成
包括(命令/状态寄存器CR,内存地址寄存器MAR,数据寄存器DR,数据计数器DC)

i/o通道 :负责输入输出的处理机,与cpu共享内存,可控制多台设备与内存的数据交换
i/o子系统层次结构
用户层io软件:实现用户接口
设备独立性软件:实现设备保护,命令,统一接口,分配与释放,提供存储空间
设备驱动程序:每类分配一个
中断处理程序:保存cpu环境
硬件设备 :包括机械部件(设备本身)和电子部件(设备控制器)
包括(与cpu的接口,与设备的接口,i/o控制逻辑)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用python中的pymsql完成如下:表结构与数据创建 1. 建立 `users` 表和 `orders` 表。 `users` 表有用户ID、用户名、年龄字段,(id,name,age) `orders` 表有订单ID、订单日期、订单金额,用户id字段。(id,order_date,amount,user_id) 2 两表的id作为主键,`orders` 表用户id为users的外键 3 插入数据 `users` (1, '张三', 18), (2, '李四', 20), (3, '王五', 22), (4, '赵六', 25), (5, '钱七', 28); `orders` (1, '2021-09-01', 500, 1), (2, '2021-09-02', 1000, 2), (3, '2021-09-03', 600, 3), (4, '2021-09-04', 800, 4), (5, '2021-09-05', 1500, 5), (6, '2021-09-06', 1200, 3), (7, '2021-09-07', 2000, 1), (8, '2021-09-08', 300, 2), (9, '2021-09-09', 700, 5), (10, '2021-09-10', 900, 4); 查询语句 1. 查询订单总金额 2. 查询所有用户的平均年龄,并将结果四舍五入保留两位小数。 3. 查询订单总数最多的用户的姓名和订单总数。 4. 查询所有不重复的年龄。 5. 查询订单日期在2021年9月1日至9月4日之间的订单总金额。 6. 查询年龄不大于25岁的用户的订单数量,并按照降序排序。 7. 查询订单总金额排名前3的用户的姓名和订单总金额。 8. 查询订单总金额最大的用户的姓名和订单总金额。 9. 查询订单总金额最小的用户的姓名和订单总金额。 10. 查询所有名字中含有“李”的用户,按照名字升序排序。 11. 查询所有年龄大于20岁的用户,按照年龄降序排序,并只显示前5条记录。 12. 查询每个用户的订单数量和订单总金额,并按照总金额降序排序。
06-03

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值