教材:《操作系统教程》(第六版)骆斌,葛季栋,费翔林编著 内容为该教材的习题答案(仅供参考,不确保是否有遗漏)
2024-06-30 18:15:41 10.59MB 操作系统 课程资源
1
Spooling,全称为Simultaneous Peripheral Operations On-line,即联机外围设备同时操作,是一种操作系统技术,主要用于解决计算机系统中I/O设备(如打印机)的速度远慢于CPU和内存速度的问题。通过Spooling技术,可以使得多个进程能够并发地使用同一台慢速I/O设备,提高系统的效率和响应时间。 在给定的文档中,描述了一个简单的Spooling打印模拟系统,主要由以下几个部分组成: 1. **输出井(Output Well)**:模拟了实际的物理打印机,用于存储待打印的任务。输出井具有固定大小(500个字节),遵循先进先出(FIFO)的原则,即先入队的任务优先被打印机处理。 2. **进程控制块(PCB, Process Control Block)**:用于存储每个打印任务的信息,包括进程号、进程状态和输出时的临时变量。在这个模拟系统中,最多可以有4个并发的打印任务。 3. **请求输出块(Request Output Block)**:存储每个打印任务的请求信息,包括请求进程的ID、本次输出信息的长度和信息在输出井的首地址。 4. **核心算法**:当新的打印任务到来时,首先检查输出井是否有空闲空间以及打印机是否空闲。如果两者条件都满足,新任务会立即送入打印机;否则,新任务会被暂时存放在输出井中,等待打印机空闲。在打印机打印完当前任务后,会按照输出井中的顺序取出下一个任务进行打印。 5. **程序实现**:使用C++编写,包含了`userpro`函数(模拟用户进程生成打印任务)、`spoolserver`函数(将任务放入输出井)和`spoolout`函数(模拟打印机输出)。`userpro`函数生成随机数据并调用`spoolserver`将其发送到输出井,`spoolserver`函数负责检查空间和处理任务入队,`spoolout`函数则模拟打印机的实际输出动作。 通过这样的模拟系统,我们可以看到Spooling如何有效地管理和调度打印任务,避免了由于打印机速度慢而阻塞其他进程执行的问题,提高了系统的整体效率。在实际操作系统中,Spooling不仅应用于打印机,还可以应用于其他慢速I/O设备,如磁带机和扫描仪等。
2024-06-28 13:24:07 188KB spooling 操作系统
1
OpenHarmony轻量级内核-LiteOS-M 思维导图 内核是一人操作系统的运算核心,决定着系统的性能和稳定性。它是基于硬件的第一层软件扩充,提供操作系统的基本功能,是操作系统工作的基础。它负责管理系统的进程、内存、外设驱动程序、支件和网络系统 https://blog.csdn.net/lanlingxueyu/article/details/136060715
2024-06-26 14:13:39 1.89MB 操作系统
1
高级操作系统的题库;还有自己整理的所有代码都运行正确的版本的题库;还有我删除重复的,适合熬夜复习的打印版本
2024-06-24 11:39:09 835KB 操作系统
1
【合并】20操作系统题库_20210308_223419.docx
2024-06-24 11:37:54 206KB
1
一、目的: 熟悉银行家算法,加深死锁有关概念的理解。 二、内容: 编制银行家算法通用程序,并检测思考题中所给状态的安全性。 三、要求: (1) 下列状态是否安全?(三个进程共享12个同类资源) 进程 已分配资源数 最大需求数 1 1 4 (状态a) 2 4 4 3 5 8 1 1 4 2 4 6 (状态b) 3 6 8 (2) 考虑下列系统状态 分配矩阵 最大需求矩阵 可用资源矩阵 0 0 1 2 0 0 1 2 1 5 2 0 1 0 0 0 1 7 5 0 1 3 5 4 2 3 5 6 0 6 3 2 0 6 5 2 0 0 1 4 0 6 5 6 问系统是否安全?若安全就
2024-06-24 11:31:26 260KB 操作系统 编程语言
1
操作系统题库-共128题.docx
2024-06-24 11:06:28 175KB 操作系统
1
乐山师范学院数据库编程期末答疑,卷子讲解,SQL server相关 如下是一个简化的员工考勤应用E-R图,请在SQL Server中创建名为YQKG的数据库,包括两个数据文件,一个日志文件,文件名按SQL Server对象命名规范定义,数据文件按10%的比例增长,数据库定义完成后输入如下样本数据。完成后请将新定义的对象及数据生成到脚本文件3_1.sql,并分离数据库。(数据表标识说明:BMXX 部门信息,QQLX 考勤类型, JBXX 基本信息,各字段定义请根据实际语义自行定义)。 2. 运行CreateTeaching.sql在系统数据库tempdb中生成解答用数据库对象,完成如下安全定义。每小题2分,共6分。 (1) 创建名为L+考生学号的登录名,密码为考生学号。完成后请将定义程序代码保存到脚本文件3_2_1.sql。 (2) 为tempdb数据库创建名为U+考生学号的带登录名的用户名,使用本题(1)中创建的登录名。完成后请将定义程序代码保存到脚本文件3_2_2.sql。 (3) 为学生表Student、课程表Course、教师表Teacher分配只读权限,成绩表分配读写权限。完成后请将程序代码保存到脚本文件3_2_3.sql。 3.运行CreateTeaching.sql在系统数据库tempdb中生成解答用数据库对象,完成如下完整性定义。每小题4分,共12分 (1) 在SC与Teacher之间定义参照完整性,外码名为FK_SC_Teacher_Tno,并定义违约处理规则:修改规则为 Cascade,删除规则为 No Action。完成后请将本操作的程序保存到脚本文件3_3_1.sql。 (2) 学生表Student中学生姓名不允许重复,将此规则保存为UQ_Sname。完成后请将本操作的程序保存到脚本文件3_3_2.sql。 (3) 在学生表上规定学生的性别只能是“男”、“女”,将此规则保存为CK_Student_Ssex。完成后请将本操作的程序保存到脚本文件3_3_3.sql。 4. 运行CreateTeaching.sql在系统数据库tempdb中生成解答用数据库对象,在SSMS中查询分析器中设计并调试如下查询,把SQL脚本代码分别保存到指定的SQL程序文件中。每小题3分,共15分 (1) 新增一位同学:200215129,王大鹏,男,23,CS,新增该生一条选课数据:该生选了数据库课程,该课主教教师未知,还未考试。完成后请将查询代码保存到脚本文件3_4_1.sql。 (2) 修改少数民族学生李勇所有选修课成绩,都加5分。完成后请将查询代码保存到脚本文件3_4_2.sql。 (3) 因为考试事故,删除计科系的所有选课信息。完成后请将查询代码保存到脚本文件3_4_3.sql。 (4) 查询与“刘晨”同一个院系的其他同学的所有信息。完成后请将查询代码保存到脚本文件3_4_4.sql。 (5) 生成选修课为达标的学生的信息,包括学号、姓名、院系、总学分,达标条件:选修课门数达到6门。完成后请将查询代码保存到脚本文件3_4_5.sql。 5. 运行CreateTeaching.sql在系统数据库tempdb中生成解答用数据库对象,为计科系生成如下选修课综合信息视图(仅包括计科系学生的选课信息,未选课的计科系学生也包括在视图的数据集中,如果未选课则课程等相关字段记为NULL,选了课但未考试则成绩等相关字段记为NULL,如果考试成绩未及格学分记为0,否则得到课程学分)。完成后请将本视图定义的程序保存到脚本文件3_5.sql。7分 6. SQL 程序设计:运行CreateTeaching.sql在系统数据库tempdb中生成解答用数据库对象,完成如下对象定义,把相应的SQL程序分别保存到指定的SQL文件中。每小题7分,共21分 (1) 为教师表定义一个名为Tr_Insert_Or_Update_Sal触发器,实现如下完整性规则:“教授的工资不得低于4000元,如果低于4000元,自动改为4000元”。请完成触发体设计,完成后请将本定义的程序保存到脚本文件3_6_1.sql。 Create Trigger Insert_Or_Update_Sal On Teacher After INSERT, UPDATE AS (2) 利用ROW_NUMBER() OVER设计一分页查询存储过程DividePage,每次调用返回指定数据表中指定页大小及页码的满足条件的记录结果集,其参数设计如下,请完成过程体设计,完成后请将本定义的程序保存到脚本文件3_6_2.sql。 Create Procedure DividePage ( @tblName varchar(255), -- 表名,不允许为空 @strOrder varchar(255), -- 排序的字段名,不允许为空 @PageSize int = 6, -- 页尺寸 @PageIndex int, -- 页码 @OrderType bit = 0, -- 设置排序类型, 非0 值则降序 @strWhere varchar(1500)='' -- 查询条件(注意: 不要加where) ) AS (3) 定义一用户函数Get_birthday,根据身份证得到生日。(提醒,身份证可能有15、18位的情况), 其参数设计如下,请完成函数体设计,完成后请将本定义的程序保存到脚本文件3_6_3.sql。 Create Function Get_birthday ( @idcardno nvarchar(50) ) returns varchar(10) As
2024-06-24 03:00:30 179.77MB 参考资料
1
《嵌入式实时操作系统uCOS-II》(第二版)配套光盘(邵贝贝)
2024-06-23 10:56:20 2.97MB uCOS-II
1