电子科技大学计算机操作系统实验指导书(2014)

合集下载

《计算机操作系统》实验指导书

《计算机操作系统》实验指导书

宁夏师范学院——数学与计算机科学学院《操作系统》实验指导《OPERATING SYSTEM》2013.08前言计算机操作系统是计算机科学与技术专业的主要专业基础课程,其实践性、应用性很强。

实践教学环节是必不可少的一个重要环节。

计算机操作系统的实验目的是加深对理论教学内容的理解和掌握,使学生较系统地掌握操作系统的基本原理,加深对操作系统基本方法的理解,加深对课堂知识的理解,为学生综合运用所学知识,在Linux环境下调用一些常用的函数编写功能较简单的程序来实现操作系统的基本方法、并在实践应用方面打下一定基础。

要求学生在实验指导教师的帮助下自行完成各个操作环节,并能实现且达到举一反三的目的,完成一个实验解决一类问题。

要求学生能够全面、深入理解和熟练掌握所学内容,并能够用其分析、设计和解答类似问题;对此能够较好地理解和掌握,并且能够进行简单分析和判断;能够熟练使用Linux用户界面;掌握操作系统中进程的概念和控制方法;了解进程的并发,进程之间的通信方式,了解虚拟存储管理的基本思想。

同时培养学生进行分析问题、解决问题的能力;培养学生完成实验分析、实验方法、实验操作与测试、实验过程的观察、理解和归纳能力。

为了收到良好的实验效果,编写了这本实验指导书。

在指导书中,每一个实验均按照该课程实验大纲的要求编写,力求紧扣理论知识点、突出设计方法、明确设计思路,通过多种形式完成实验任务,最终引导学生有目的、有方向地完成实验任务,得出实验结果。

任课教师在实验前对实验任务进行一定的分析和讲解,要求学生按照每一个实验的具体要求提前完成准备工作,如:查找资料、设计程序、完成程序、写出预习报告等,做到有准备地上机。

进行实验时,指导教师应检查学生的预习情况,并对调试过程给予积极指导。

实验完毕后,学生应根据实验数据及结果,完成实验报告,由学习委员统一收齐后交指导教师审阅评定。

目录操作系统实验大纲 (1)第一部分实验环境及所用系统函数介绍 (3)1.1 Linux操作系统简介 (3)1.2 Linux的使用 (3)第二部分实验内容 (7)实验一熟悉LINUX基本命令及编程环境 (7)实验二进程管理 (10)实验三进程调度 (14)实验四进程间通信 (19)实验五存储管理实验 (22)操作系统实验大纲一、教学目的和要求操作系统课程是一门理论性很强的专业课,操作系统实验是该课程的辅助课程。

电大操作系统实验报告3_ 进程管理实验

电大操作系统实验报告3_ 进程管理实验

电大操作系统实验报告3_ 进程管理实验电大操作系统实验报告 3 进程管理实验一、实验目的进程管理是操作系统的核心功能之一,本次实验的目的是通过实际操作和观察,深入理解进程的概念、状态转换、进程调度以及进程间的通信机制,掌握操作系统中进程管理的基本原理和方法,提高对操作系统的整体认识和实践能力。

二、实验环境本次实验使用的操作系统为 Windows 10,编程语言为 C 语言,开发工具为 Visual Studio 2019。

三、实验内容及步骤(一)进程的创建与终止1、编写一个 C 程序,使用系统调用创建一个子进程。

2、在父进程和子进程中分别输出各自的进程 ID 和父进程 ID。

3、子进程执行一段简单的计算任务,父进程等待子进程结束后输出结束信息。

以下是实现上述功能的 C 程序代码:```cinclude <stdioh>include <stdlibh>include <unistdh>int main(){pid_t pid;pid = fork();if (pid < 0) {printf("创建子进程失败\n");return 1;} else if (pid == 0) {printf("子进程:我的进程 ID 是%d,父进程 ID 是%d\n",getpid(), getppid());int result = 2 + 3;printf("子进程计算结果:2 + 3 =%d\n", result);exit(0);} else {printf("父进程:我的进程 ID 是%d,子进程 ID 是%d\n",getpid(), pid);wait(NULL);printf("子进程已结束\n");}return 0;}```编译并运行上述程序,可以观察到父进程和子进程的输出信息,验证了进程的创建和终止过程。

(二)进程的状态转换1、编写一个 C 程序,创建一个子进程,子进程进入睡眠状态一段时间,然后被唤醒并输出状态转换信息。

电子科技大学《计算机操作系统》作业考核试题及答案参考

电子科技大学《计算机操作系统》作业考核试题及答案参考

电子科技大学《计算机操作系统》作业考核试题及答案参考第一部分:选择题1. 什么是操作系统?操作系统是计算机系统的一个重要组成部分,它是一种管理计算机硬件和软件资源的系统软件,为用户提供一个操作计算机的环境。

2. 操作系统的主要功能是什么?操作系统的主要功能包括进程管理、文件管理、内存管理、设备管理和网络管理。

3. 进程是指什么?进程是指计算机中正在执行的程序的实例。

每个进程都有自己的内存空间、寄存器和其他系统资源,它们可以并行或交替执行。

4. 什么是进程调度算法?进程调度算法是操作系统使用的一种策略,用于决定哪个进程应当被调度并占用处理器资源。

常见的调度算法有先来先服务、短作业优先、轮转法等。

5. 文件系统是什么?文件系统是操作系统管理计算机存储设备上文件的一种方式,它可以对文件进行存储、组织、管理和访问。

第二部分:简答题1. 请简要解释操作系统的内存管理功能。

操作系统的内存管理功能包括内存分配、内存保护和内存回收。

内存分配是指根据程序的需要,将可用的内存分配给进程;内存保护是指防止一个进程越界访问其他进程或操作系统的内存;内存回收是指当一个进程退出或者不再需要内存时,将其所占用的内存释放出来,以便其他进程使用。

2. 请简要解释死锁是什么,以及如何避免死锁?死锁是指两个或多个进程因为互相等待对方所持有的资源而无法继续执行的状态。

为避免死锁,可以采取以下措施:破坏死锁产生的四个必要条件(互斥条件、请求与保持条件、不剥夺条件、循环等待条件)之一;使用资源分级、资源有序性等算法进行资源分配;按照固定的顺序申请和释放资源,避免循环等待。

3. 请简要解释虚拟内存的概念及其作用。

虚拟内存是一种操作系统的内存管理技术,它可以将物理内存和磁盘的空间组合起来,提供给进程使用。

虚拟内存的作用是扩大了进程的可用地址空间,允许大于实际物理内存的程序运行;并且能够将不常用的数据或程序部分保存到磁盘上,从而释放出物理内存供其他进程使用。

电子科技大学《计算机操作系统》第2章 并发与进程-调度共73页

电子科技大学《计算机操作系统》第2章 并发与进程-调度共73页
(换入)。 – 只有支持进程挂起的操作系统才具有中程调度功能。
2.5.2 调度的类型
• 同时具有三级调度的调度队列模型
长程调 度
时间片用完
就绪队列
处理机完成ຫໍສະໝຸດ 就绪/挂起队列短程调度
阻塞/挂起队列
阻塞队列 事件发生
中程调度 事件等待
2.5.3 进程调度算法
• 调度算法
– 根据系统的资源分配策略所规定的资源分配算法 – 对于不同的系统目标,通常采用不同的调度算法
进程名 产生时间 服务时间 优先级 时间片
P1
0
2
2
P2
1
6
1
1
P3
2
1
4
P4
3
5
3
2.5.3.1 先来先服务(FCFS)
进程名 产生时间
P1
0
P2
1
P3
2
P4
3
服务时间 2 6 1 5
优先级 2 1 4 3
时间片 1
P2 P1
P4 P3
2 4 6 8 10 12 14 16
t
P1 P2 P3 P4
当一个新进程加入就绪队列时,它可能比当前运行 的进程具有更短的剩余时间。只要新进程就绪,调度程 序就可能抢占当前正在运行的进程。
• 优点
– 既不像FCFS那样偏爱长进程,也不像RR算法那样会产 生额外的中断,从而减少了开销。
– 周转时间方面,SRT比SJF性能要好,短作业可以立即 被选择执行。
2.5.3.5 剩余时间最短者优先算法
在创建进程时所赋予的优先级可随进程的推进或随 其等待时间的增加而改变,以便获得更好的调度性能。
• 调整时机
– 时钟中断 – 进程切换 – 进程终止

电子科技大学计算机操作系统—操作系统实验

电子科技大学计算机操作系统—操作系统实验

附件1操作系统上机实验进程调度实验时间:16 机时实验验收时间:17~18周实验成绩:占总成绩的20%一、实验目的和要求1.目的进程是操作系统最重要的概念之一,进程调度又是操作系统核心的主要内容。

本实习要求学生独立地用高级语言编写和调试一个进程调度程序,模拟各种调度算法。

调度算法可任意选择或自行设计,例如,简单轮转法和优先数法等。

本实验可加深对于进程调度和各种调度算法的理解。

2.要求(1)设计一个有n(n≥8)个进程并行的进程调度程序。

每个进程由一个进程控制块(PCB)表示。

进程控制块通常应包含下述信息:进程名(或序号)、进程优先数、进程需要运行的时间、占用CPU的时间以及进程的状态等(要求包括4种基本状态:运行、就绪、阻塞、完成),PCB块的内容应根据调度算法的不同特点而增删。

(2)调度程序应包含3种或3种以上不同的调度算法,运行时可任意选一种,以利于各种算法的分析比较。

其中至少有一种为综合调度算法,并要求是自己设计的算法。

(3)系统应能直观、准确地动态显示(用动态的表或图)各进程状态和参数的变化情况,便于观察诸进程调度的动态显示过程。

(4)要求完成一个完整的软件系统,用户界面友好,操作简便,可采用菜单选择或图形用户界面(GUI)实现。

说明:在windows 环境下开发,也可用其它工具或软件实现进程调度过程的模拟。

要求画出至少一个综合调度算法的实现流程图。

二、调度算法1.算法本程序可选用来先服务(FCFS)算法、最短CPU运行期优先(SCBF)算法、最高优先权(HPF)算法、时间片轮转(RR)算法及多级反馈队列算法等对多个进程进行调度。

同时注意对自己设计的综合调度算法要认真分析其特点。

每个进程处于运行、就绪、等待、完成四种状态,并假定起始状态都是就绪状态。

为了便于处理,程序中进程的运行时间以时间片为单位计算。

各进程的优先数或轮转时间片数、以及进程需要运行的时间片数,均由伪随机数发生器产生。

进程控制块结构如下图所示:2.算法举例以两种典型算法为例说明实现的算法:⑴优先数法(动态优先数)系统中各进程的初始优先级与进程类型(前台或后台,交互或批处理,计算或I/O)有关。

电子科大计算机-操作系统实验报告-级

电子科大计算机-操作系统实验报告-级

电子科技大学实验报告学生姓名:郫县LBJ 学号:指导教师:温柔可爱的刘杰彦实验地点:主楼A2-413 实验时间:2017年4月22日上午一、实验室名称:计算机学院主楼机房二、实验项目名称:进程与资源管理实验分工:郫县LBJ 进程管理设计郫县小胖子资源管理设计郫县威斯布鲁克进程调度与时钟中断设计三、实验学时:2四、实验原理:此处的实验原理在指导书上非常丰富,因此不照搬过来,主要写出所要使用到知识点,具体实现过程中的原理分析见报告第八部分“实验步骤”处。

(一)总体设计系统总体架构如图1所示,最右边部分为进程与资源管理器,属于操作系统内核的功能。

要求能够设计与实现一个简单的进程与资源管理器,具有如下功能:完成进程创建、撤销和进程调度;完成多单元 (multi_unit)资源的管理;完成资源的申请和释放;完成错误检测和定时器中断功能。

图1 系统总体结构(二) Test shell设计应具有的功能:1、从终端或者测试文件读取命令;2、将用户需求转换成调度内核函数(即调度进程和资源管理器);3、在终端或输出文件中显示结果:如当前运行的进程、错误信息等。

(三)进程管理设计1、进程状态与操作2、进程控制块结构PCB3、主要函数:创建进程、撤销进程(四)资源管理设计1、主要数据结构RCB2、请求资源3、释放资源(五)进程调度与时钟中断设计关键:使用基于优先级的抢占式调度策略,在同一优先级内使用时间片轮转算法。

参考课上ppt:五、实验目的:设计和实现进程与资源管理,并完成Test shell的编写,以建立系统的进程管理、调度、资源管理和分配的知识体系,从而加深对操作系统进程调度和资源管理功能的宏观理解和微观实现技术的掌握。

六、实验内容:设计与实现一个简单的进程与资源管理器,要求具有如下功能:完成进程创建、撤销和进程调度;完成多单元 (multi_unit)资源的管理;完成资源的申请和释放;完成错误检测和定时器中断功能。

电子科技大学计算机操作系统—第1章 操作系统概述

电子科技大学计算机操作系统—第1章 操作系统概述
高其利用率。 2. 用户角度 为用户提供使用计算机的环境和服务。
计算机四大类资源
C P U 内 存 外 设 信息文件














设 备 管 理
文 件 管 理
1. 3 操作系统的功能
一、处理机管理
基本任务是:按照一定策略,对处理机进行分配 及进行资源回收。
在多道程序系统中,处理机的分配和运行都是以 进程为单位的,故处理机管理又归结为进程管理。
内存分配与回收
存储保护
地址映射
内存扩充
1. 3 操作系统的功能
三、设备管理 基本任务是为用户提供统一的与设备无关的
接口。对各种外设进行调度、分配、实现设备的 中断处理及错误处理等。
缓冲技术
虚拟设备技术
1. 3 操作系统的功能
四、文件管理 即对计算机软件资源的管理。基本任务是:
1.负责文件的物理存储空间的组织分配与回收。 2.实现文件的按名存取。 3.实现文件与目录的创建、读、写、及修改、
程序 A 程序 B 程序 C 程序 D
调度程序
程序B I/O请求 程序C I/O请求
程序B I/O完成 程序C I/O完成
程序D I/O请求
t
多道程序系统的工作情况
1. 1 操作系统的形成与发展
用户程序 监督程序 I/O 操作
I/O中断请求 启动I/O
t1 t2
I/O完成
I/O中断请求 启动I/O
1.2 操作系统的分类
2.实现分时系统有哪些主要问题需要解决?
按“时间片轮转”的调度策略; 响应时间 — 分时系统是否成功的关键。

电大操作系统实验2:进程管理实验

电大操作系统实验2:进程管理实验

电大操作系统实验2:进程管理实验
实验目的:
1.加深对进程概念的理解,特别是进程的动态性和并发性。

2.了解进程的创建和终止。

3.学会查看进程的状态信息。

4.学会使用进程管理命令。

实验要求:
1.理解有关进程的概念,能够使用ps命令列出系统中进
程的有关信息并进行分析。

2.理解进程的创建和族系关系。

3.能够使用&,jobs,bg,at等命令控制进程的运行。

实验内容:
1.使用ps命令查看系统中运行进程的信息。

实验环境:
实验步骤和结果:
1.输入ps命令,可以报告系统当前的进程状态。

2.输入ps-e命令,可以显示系统中运行的所有进程,包括系统进程和用户进程。

3.输入ps-f命令,可以得到进程的详细信息。

进程控制:
1.后台进程
1) $grep "注册用户名" /etc/passwd。

/tmp/abc &
2.作业控制
1) 进程休眠60秒Sleep 60 &
2) 进程休眠30秒Sleep 30 &
3) 查看进程状态Jobs
4) 将睡眠30秒的sleep命令放在前台执行fg%2
3.发送中断信号
1) 后台运行sleep命令$sleep 120 &
2) 查看sleep进程的状态$ps-p pid
3) 终止sleep命令$kill -9 pid。

计算机操作系统实验指导书_windows

计算机操作系统实验指导书_windows

《操作系统原理》实验指导书计算机科学与技术系2010年9月目录《操作系统原理》实验教学大纲(修订) (1)实验考核方式与基本要求 (3)实验一进程控制描述与控制 (12)实验二并发与调度 (24)实验三存储管理 (31)实验四设备管理 (40)实验五文件管理与系统安全 (44)附录实验报告参考规范 (64)《操作系统原理》实验教学大纲(修订)课程编号:0433314课程名称:操作系统原理实验学时:14一、本实验课的性质、任务与目的操作系统作为计算机专业的一门专业基础课,是计算机专业的核心课程之一,学好与否直接关系到学生是否能更好地学习后续课程。

通过本实验课程的学习,使学生理解与掌握操作系统设计所遵循的基本原理,基本方法,建立多道程序设计环境下的并行程序设计的思维方式。

此外,操作系统用到的各种算法也是学生加强算法锻炼的好机会,对日后从事系统开发方面的工作有直接的借鉴作用。

本实验课程在操作系统原理课程教学中占有重要地位,目的是让学生及时掌握和巩固所学的基本原理和基础理论,加深理解。

提高学生自适应能力,为将来使用和设计各类新的操作系统打下良好的基础。

二、本实验课所依据的课程基本理论计算机操作系统,操作系统中所介绍的重要算法。

三、实验类型与要求序号实验内容内容提要实验要求实验时数实验类型每组人数所在实验室名称备注一进程控制描述与控制操作系统界面、进程管理必修 2 验证 2 系机房二并发与调度进程并发、进程状态转换必修 2 验证 2 系机房三存储管理内存空间分配及虚拟存储器必修 2 验证 2 系机房四设备管理设备分配与回收必修 2 验证 2 系机房五文件管理与系统安全文件系统目录结构,文件操作及操作系统安全任选 2 验证 2 系机房六操作系统功能模拟设计实验操作系统功能模拟设计并实现必修 4 设计3-4 系机房四、每组人数与实验学时数序号实验内容实验时数每组人数一进程控制描述与控制 2 2二并发与调度 2 2三存储管理 2 2四设备管理 2 2五文件管理与系统安全 2 2六操作系统功能模拟设计实验 4 3-4五、考核方式与评分办法考核方式:在规定时间内,按要求设计相应的模拟系统并上机调试运行,写出详细的实验报告,在机上向教师演示自己设计的模拟系统。

操作系统实验指导书

操作系统实验指导书
printf("pid %d is already exist!\n",para[0]); return -1; } if(p->node->pid == para[1]) //find parent pcb { pflag=1; pp = p; } } if(!pflag) { printf("parent id %d is not exist!\n",para[1]); return -2; } //init new pcb p1 = new pnode; p1->node=new pcb; p1->node->pid = para[0]; p1->node->ppid = para[1]; p1->node->prio = para[2]; p1->sub=NULL; p1->next=NULL; p1->brother=NULL; //add to process tree if(!pp->sub) pp->sub=p1; else { for(p=pp->sub;p->brother;p=p->brother); p->brother=p1; } // add to process link for(p=plink;p->next;p=p->next); p->next=p1;
三、实验原理
1)进程控制块 为了描述和控制进程的运行,系统为每个进程定义了一个进程控制块(PCB),它是进程 实体的一部分,是操作系统管理进程最重要的数据结构。其主要包含四类信息: (1) 进程标识符 它唯一地标识一个进程。通常包括进程号 pid,父进程号 ppid 和用户号 uid。 (2) 处理机状态 处理器的状态通常由处理机的各种寄存器中的内容组成。PCB 存放中断(阻塞,挂起)时的 各寄存器值,当该进程重新执行时,可以从断点处恢复。主要包括:

计算机操作系统实验指导书

计算机操作系统实验指导书

《计算机操作系统》实验指导书适用专业:计算机科学与技术信息与计算机江南大学物联网工程学院2014年5月前言计算机操作系统(Operating System简称OS)是计算机中最重要的系统软件,也是最活跃的学科之一,是计算机相关本科专业的核心课程。

通过本课程的学习使学生掌握操作系统的基本概念、技术、原理,具备一定的从不同层次分析与使用操作系统功能的能力。

了解计算机操作系统方面的新技术、新理论与新发展。

本实验指导书,是根据《操作系统》课程教学大纲的要求而编写的,目的是让学生能够进一步了解操作系统的基本概念、原理,通过综合性、验证性和设计性等实验,熟练掌握操作系统的运行机理和各种算法思想,尤其是操作系统的核心功能。

同时还希望通过实验进一步提高学生的动手能力和综合运用先修课程的能力。

由于编写仓促,难免有错误和不足之处,恳请读者不吝赐教。

目录前言 (1)实验一进程调度 (3)实验二银行家算法 (6)实验三存储管理 (10)实验一进程调度实验学时:4学时实验类型:设计实验要求:必修一、实验目的多道程序设计中,经常是若干个进程同时处于就绪状态,必须依照某种策略来决定那个进程优先占有处理机。

因而引起进程调度。

本实验模拟在单处理机情况下的处理机调度问题,加深对进程调度的理解。

二、实验内容1.优先权法、轮转法简化假设1)进程为计算型的(无I/O)2)进程状态:ready、running、finish3)进程需要的CPU时间以时间片为单位确定2.算法描述1)优先权法——动态优先权当前运行进程用完时间片后,其优先权减去一个常数。

2)轮转法三、流程图产生n 需的时间片数,已占用CPU 的时间片数置为0按进程产生的先后次序拉成就绪队列链=0?撤销该进程就绪队列为空吗?=轮转时间片数?0 NYYY 结束N开始键盘输入进程数n ,和调度方法的选择优先权法? 轮转法产生n 个进程,对每个进程产生一个PCB ,并用随机数产生进程的优先权及进程所需的CPU 时间 按优先权大小,把n 个进程拉成一个就绪队列 撤销进程就绪队列为空?结束NYY四、实验要求1.产生的各种随机数的取值范围加以限制,如所需的CPU时间限制在1~20之间。

2014年现代电子技术实验报告(电子科大)

2014年现代电子技术实验报告(电子科大)

电子科技大学学院实验报告实验名称现代电子技术综合实验姓名:学号:评分:教师签字电子科技大学教务处制电子科技大学实验报告学生姓名:学号:指导教师:熊万安实验地点:科A333 实验时间:第七、八周一、实验室名称:电子技术综合实验室二、实验项目名称:三、实验学时:32四、实验目的与任务:1、熟悉系统设计与实现原理2、掌握KEIL C51的基本使用方法3、熟悉SMART SOPC实验箱的应用4、连接电路,编程调试,实现各部分的功能5、完成系统软件的编写与调试五、实验器材1、PC机一台2、SMART SOPC实验箱一套六、实验原理、步骤及内容实验原理:1、数码管静态显示与动态显示原理:静态显示方式LED显示器工作方式有两种:静态显示方式和动态显示方式。

静态显示的特点是每个数码管的段选必须接一个8位数据线来保持显示的字形码。

当送入一次字形码后,显示字形可一直保持,直到送入新字形码为止。

这种方法的优点是占用CPU时间少,显示便于监测和控制。

缺点是硬件电路比较复杂,成本较高。

动态显示动态显示的特点是将所有位数码管的段选线并联在一起,由位选线控制是哪一位数码管有效。

选亮数码管采用动态扫描显示。

所谓动态扫描显示即轮流向各位数码管送出字形码和相应的位选,利用发光管的余辉和人眼视觉暂留作用,使人的感觉好像各位数码管同时都在显示。

动态显示的亮度比静态显示要差一些,所以在选择限流电阻时应略小于静态显示电路中的。

图1 数码管的动态扫描与显示原理图2、I2C工作原理:为了使这些相似之处对系统设计者和器件厂商都得益而且使硬件效益最大电路最简单Philips开发了一个简单的双向两线总线实现有效的IC之间控制这个总线就称为Inter IC或I2C总线现在Philips包括超过150种CMOS和双极性兼容I2C总线的IC 可以执行前面提到的三种类型的功能所有符合I2C总线的器件组合了一个片上接口使器件之间直接通过I2C总线通讯这个设计概念解决了很多在设计数字控制电路时遇到的接口问题。

《计算机操作系统综合实验》实验指导书

《计算机操作系统综合实验》实验指导书

西南科技大学(SouthWest University of Science and Technology) E x p e r i m e n t a l I n s t r u c t o r o f C o m p u t e r O p e r a t i n g S y s t e m 计算机操作系统 综合实验指导书 应用教研室 编写 计算机科学与技术学院 二 00 七年C o m p u t e r S c i e n c e a n d T e c h n o l o g y前言FOREWORDFOREWORDFOREWORD实验课程是理论课程的有力补充,通过操作系统上机实验,培养学生程序设计的方法和技巧,提高学生编制清晰、合理、可读性好的程序的能力,加深对操作系统理论的理解。

使学生更好地掌握操作系统的基本概念、基本原理及基本功能,具有分析现代操作系统,设计和开发简单操作系统部分功能的基本能力。

对于操作系统理论的掌握与进一步学习具有非常重要的意义。

实验指导书第一章是基础知识概述,主要介绍了实验环境和实验工具。

第二章是要求,包括实验选题要求、过程要求、实验报告要求、实验成绩评价和评分标准。

第三章是实验内容,计算机操作系统综合实验内容主要围绕计算机操作系统理论课程进行安排,一共包括10 个实验。

实验1 和实验2 涉及进程创建和撤销相关理论;实验3 涉及信号量相关理论;实验4 和实验8 涉及进程调度相关理论;实验5 涉及死锁相关理论;实验6 涉及页面置换相关理论;实验7 涉及磁盘调度相关理论;实验9 涉及内存管理相关理论;实验10 是一个真实的内核实验,它涉及了可执行文件的装载与重定位。

计算机操作系统综合实验指导书主要帮助学生掌握和理解操作系统原理相关理论,让更抽象的理论在实践中得到更好的理解。

适合已经学习过操作系统相关理论的学生使用。

《计算机操作系统综合实验》实验指导书建设小组2007 年5 月目录第一章基础知识概述 (1)1.1 实验环境 (1)1.2 实验工具 (1)第二章实验要求 (3)2.1 实验体系结构......................................................................................错误!未定义书签。

操作系统实验指导书(完整版)

操作系统实验指导书(完整版)

《计算机操作系统实验》指导书(第二版)实验一LINUX的安装与使用 (2)实验二进程管理与通信 (27)实验三存储管理——页面置换算法模拟 (51)实验四文件管理 (56)实验五LINUX服务器配置(选做) (62)实验报告撰写指导 (72)韶关学院信息工程学院计算机系教师:陈正铭2007-9-10实验一LINUX的安装与使用【实验目的】1、了解与掌握RED HAT LINUX 9.0的安装过程。

2、熟悉LINUX的命令及使用格式与常用基本命令。

【实验内容】1、使用图形化安装模式安装RED HAT LINUX 9.0。

2、使用WINDOWS操作系统中的远程登录程序telnet.exe 登录LINUX。

3、练习使用LINUX的常用基本命令如ls、cd、who、pwd、ps、pstree、top等。

4、掌握WINDOWS和LINUX之间的文件共享方法。

【实验指导】一、Red Hat Linux 9光盘启动安装过程1、准备工作(1)购买或下载Redhat9的安装光盘(3张盘)或镜像文件,下载地址:校园网FTP站点。

或从红帽子主站下载∶/(2)在硬盘中至少留2个分区给安装系统用,挂载点所用分区推荐4G以上,交换分区在256M 左右比较适合,文件系统格式不论,反正安装过程会重新格式化。

(假如使用虚拟机vm安装建议最少留6G存储空间)(3)记录下你电脑中下列设备型号∶鼠标、键盘、显卡、网卡、显示器。

及网络设置用到的IP地址、子网掩码、默认网关和DNS名称服务器地址等信息。

2、安装红帽子Red Hat Linux 9将光驱设为第一启动盘,放入第一张安装光盘后重新启动电脑,如果你的光驱支持自启动, 如无意外将出现如下图:直接按回车键后将出现如下图1 ,如果你不处理30秒后也会自动进入。

在图1中提示:是否测试安装CD的内容的完整性,选―OK‖开始测试安装CD;选―Skip‖不测试安装CD开始安装出现图6所示,如果是第一次安装当然要测试安装CD,选―OK‖后回车,出现如下图2选―Test‖测试安装光盘的文件,选―Eject CD‖测试光盘以外的安装文件,这里我选择―Test‖后回车,出现如下图3正在测试第一张安装CD,测试完后显示如下图4所示看到上图最后一行英文―It is OK to install from this med ia‖说明这张安装CD是OK的,按―Enter‖键回车后,显示如下图5所示选择―Continue‖并回车开始安装。

杭州电子科技大学操作系统课程设计指导书2014

杭州电子科技大学操作系统课程设计指导书2014

操作系统课程设计指导书梁红兵赵伟华2013年2月计算机学院目录第一章操作系统课程设计的内容与实施方法............................................ - 3 - 1.1 操作系统课程设计总体要求............................................................ - 3 - 1.2 操作系统课程设计的内容................................................................ - 3 - 1.3 操作系统课程设计实施方案............................................................ - 4 - 第二章基于DOS的多任务系统的实现...................................................... - 6 - 2.1 设计目的和内容要求........................................................................ - 6 - 2.2 线程描述 ...................................................................................... .... - 7 - 2.3 线程的创建和撤消........................................................................ - 10 - 2.4 线程调度设计................................................................................ - 13 - 2.5 基本实例程序的实现 .................................................................... - 31 - 2.6线程的阻塞和唤醒........................................................................ - 35 - 2.7 线程的同步与互斥.......................................................................... - 36 - 2.8 利用消息缓冲队列通信机制实现线程间通信.............................. - 37 - 第三章简单文件系统的实现 .................................................................... - 43 - 3.1 设计目的和内容要求........................................................................ - 43 - 3.2 预备知识....................................................................................... ..... - 45 - 3.3实例系统的设计与实现..................................................................... - 49 - - 2 -操作系统课程设计第一章操作系统课程设计的内容与实施方法 1.1 操作系统课程设计总体要求1.遵守机房纪律,服从机房调度。

操作系统指导书

操作系统指导书

《计算机操作系统》实验指导书适用专业:计算机科学与技术信息与计算机江南大学物联网工程学院2015年4月前言计算机操作系统(Operating System简称OS)是计算机中最重要的系统软件,也是最活跃的学科之一,是计算机相关本科专业的核心课程。

通过本课程的学习使学生掌握操作系统的基本概念、技术、原理,具备一定的从不同层次分析与使用操作系统功能的能力。

了解计算机操作系统方面的新技术、新理论与新发展。

本实验指导书,是根据《操作系统》课程教学大纲的要求而编写的,目的是让学生能够进一步了解操作系统的基本概念、原理,通过综合性、验证性和设计性等实验,熟练掌握操作系统的运行机理和各种算法思想,尤其是操作系统的核心功能。

同时还希望通过实验进一步提高学生的动手能力和综合运用先修课程的能力。

由于编写仓促,难免有错误和不足之处,恳请读者不吝赐教。

目录前言 (1)实验一进程调度 (3)实验二作业调度实验 (6)实验三银行家算法 (9)实验四存储管理 (13)实验一进程调度实验学时:4学时实验类型:设计实验要求:必修一、实验目的多道程序设计中,经常是若干个进程同时处于就绪状态,必须依照某种策略来决定那个进程优先占有处理机。

因而引起进程调度。

本实验模拟在单处理机情况下的处理机调度问题,加深对进程调度的理解。

二、实验内容1.优先权法、轮转法简化假设1)进程为计算型的(无I/O)2)进程状态:ready、running、finish3)进程需要的CPU时间以时间片为单位确定2.算法描述1)优先权法——动态优先权当前运行进程用完时间片后,其优先权减去一个常数。

2)轮转法三、流程图产生n 需的时间片数,已占用CPU 的时间片数置为0按进程产生的先后次序拉成就绪队列链=0? 撤销该进程就绪队列为空吗?=轮转时间片数?NYYY 结束N开始键盘输入进程数n ,和调度方法的选择优先权法? 轮转法产生n 个进程,对每个进程产生一个PCB ,并用随机数产生进程的优先权及进程所需的CPU 时间 按优先权大小,把n 个进程拉成一个就绪队列 撤销进程就绪队列为空?结束NYY四、实验要求1.产生的各种随机数的取值范围加以限制,如所需的CPU时间限制在1~20之间。

计算机操作系统

计算机操作系统

电子科技大学计算机科学与工程学院标准实验报告(实验)课程名称计算机操作系统电子科技大学教务处制表电子科技大学实验报告学生姓名:段骞学号:2923105006 指导教师:实验地点:实验时间:一、实验室名称:二、实验项目名称:进程管理三、实验学时:4四、实验原理:进程创建:由程序段、相关的数据段和PCB三部分构成,所谓创建进程,实质上是创建进程实体中的PCB;而撤消进程,实质上是撤消进程的PCB。

进程并发:指多个进程实体同存于内存中,且能在一段时间内同时运行,进程执行要由调度程序管理才能占用CPU执行。

在操作系统中,进程的实质是进程实体的一次执行过程。

在实验中,通过API可以调度执行一个程序(创建一个进程),在多个程序的执行的情况下,可以观察进程的并发(通过fork创建子进程)。

五、实验目的:(1)加深对进程概念的理解,明确进程和程序的区别;(2)进一步认识并发执行的实质;(3)分析进程竞争资源现象,学习解决进程互斥的方法;(4)了解统中进程通信的基本原理。

六、实验内容:(1)进程的创建编写一段源程序,使系统调用创建两个子进程,当此程序运行时,在系统中有一个父进程和两个子进程活动。

让每一个进程在屏幕上显示一个字符:父进程显示字符“a”;子进程分别显示字符“b”和字符“c”。

试观察纪录屏幕上的显示结果,并分析原因。

(2)进程的控制修改已编写的程序,将每个进程输出一个字符改为每个进程输出一句话,在观察程序执行时屏幕出现的现象,并分析原因。

七、实验器材(设备、元器件):PC机及VC++软件八、实验步骤:1.用任何一种编辑器(最好是VC++自带的)编辑源文件;2.编译、链接、运行程序;3.调试程序,直到得到正确结果。

九、实验数据及结果分析:1.附参考程序如下:“Fork.cpp”#pragma once#define WIN32_LEAN_AND_MEAN#include<stdio.h>#include<tchar.h>#include"stdafx.h"#include<windows.h>#include<iostream>using namespace std;int fork(const char* pszApplication,HANDLE& hProcess) //声明创建进程的函数fork,该函数在父进程中返回子进程ID,在子进程中返回{ //失败返回-1STARTUPINFO si={sizeof(si)};PROCESS_INFORMATION pi;if(!CreateProcess(pszApplication,NULL,NULL,NULL,FALSE,0,NULL,NULL,&si,&pi)) return -1;else{hProcess=pi.hProcess;return pi.dwProcessId;}}void lockf(HANDLE hObj){WaitForSingleObject(hObj,INFINITE);}int main(int argc, char* argv[]){HANDLE hProcess1,hProcess2;int child1=fork("..\\printStr1.exe",hProcess1);if(-1==child1){cout << "错误~!\n";return -1;}//lockf(hProcess1);int child2=fork("..\\printStr2.exe",hProcess2);if(-1==child2){cout << "fork error!\n";return -1;}//lockf(hProcess2);cout<<"这是c进程\n";return 0;}printStr1.cpp#include<iostream>using namespace std;int main(){cout<<"这是a进程"<<endl;return 0;}printStr2.cpp#include<iostream>using namespace std;int main(){cout<<"这是b进程"<<endl;return 0;}2.结果分析当不对其加锁时,结果为当对其加锁时,结果为根据实际执行情况,对照程序进行分析。

电大计算机本科操作系统实验指导

电大计算机本科操作系统实验指导

操作系统(本科)实验指导实验1 安装Linux 系统 (2)1.1实验目的 (2)1.2实验要求 (2)1.3实验步骤 (2)1.3.1安装准备 (2)1.3.2从光盘安装Linux系统 (2)1.3.3从硬盘安装Linux系统 (2)1.3.4启动和关闭Linux系统 (3)实验2 Linux 使用及Shell编程 (5)2.1实验目的 (5)2.2实验要求 (5)2.3实验步骤 (5)2.3.1登录和退出Linux系统 (5)2.3.2 Linux常用命令 (5)2.3.3 vi基本操作 (6)2.3.4 Shell编程 (7)实验3 进程管理 (10)3.1实验目的 (10)3.2实验要求 (10)3.3实验步骤 (10)3.3.1观察进程状态 (10)3.3.2进程控制 (12)3.3.3发送中断信号 (13)3.3.4减轻系统负载 (15)实验4 存储管理 (16)4.1实验目的 (16)4.2实验要求 (16)4.3实验步骤 (16)4.3.1使用sar命令监视内存的使用情况 (16)4.3.2使用swap命令监视对换区的使用情况 (19)实验5 文件管理 (20)5.1实验目的 (20)5.2实验要求 (20)5.3实验步骤 (20)5.3.1使用pwd,cd ,ls等命令浏览文件系统 (20)5.3.2使用cat,cp,mv,head,tail,rm等命令查看文件 (20)5.3.3使用find,grep命令进行文件查找和模式匹配 (21)5.3.4使用chmod命令修改文件存取权限 (22)实验1 安装Linux 系统1.1实验目的学会安装和配置Linux系统。

1.2实验要求1.为Linux安装预留硬盘分区。

2.正确建立Linux分区。

3.正确安装、启动和关闭Linux系统。

1.3实验步骤1.3.1安装准备1.准备安装软件(1)购买SuSE安装光盘或下载SuSE安装文件。

(2)找到一张Windows引导光盘,为从硬盘安装SuSE做准备。

电子科技大学-计算机学院-操作系统实验-薛瑞尼教学班

电子科技大学-计算机学院-操作系统实验-薛瑞尼教学班


场景2

3
编写银行家算法程序 INPUT: 从文件读入系统资源初始化表,格 式如下图:

Process P1 P2
Max
Allocation R1 R2 R3 1 0 0 5 1 1
Need
R1 R2 R3 3 2 2 6 1 3
R1 R2 R3 2 2 2 1 0 2
P3
P4

3 1 4
输出: Nhomakorabea物理地址(物理块号,块内便宜)
5

编写程序计算文件逻辑地址到物理地址映 射
条件:自行定义inode结构(必须包括indirect blocks) 输入:文件逻辑地址 输出:物理地址(物理块号,块内偏移)

6
4 2 2
2 1 1
0 0 2
1 0 3
4 2 0
OUTPUT: 给出调度顺序,或者死锁提示。
4

编写多级页表页式存储逻辑地址到物理地 址映射计算程序。
条件:32bit地址空间 输入:

页记录大小(如 4Byte) 页大小(如 4KB) 页表级数(如 2表示2级页表,n表示n级页表) 逻辑地址
4个实验; 两次上机; 建议:线下完成,上机时优化


抽查

严重提示:一旦发现抄袭,抄袭和被抄袭 者分数均为0。
2

分别在以下场景实现生产者消费者问题

场景1


同一进程内启动一组生产者线程和一组消费者线 程 缓冲区为本进程的全局变量 启动一组生产者进程和一组消费者进程 同一个数据文件为缓冲区
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

电子科技大学计算机科学与工程学院
实验指导书
(实验)课程名称:计算机操作系统
电子科技大学教务处制表
实验一进程调度算法设计
●实验所属系列:操作系统课程实验
●实验对象:本科
●相关课程及专业:计算机操作系统,计算机专业
●实验类型:配套上机
●实验时数:4学时
实验目的
用C语言编写和调试进程调度程序,以加深对进程概念及进程调度算法的理解。

实验内容
实现短进程优先调度算法(SPF)和时间片轮转调度算法(RR)。

实验要求
⏹进程通过定义一个进程控制块的数据结构(PCB)来表示;
⏹每个进程需要赋予进程ID、进程到达时间、进程需要运行的总时间的属
性;
⏹在RR中,以1为时间片单位;
⏹运行时,输入进程序列,按照进程的ID输出其执行序列,具体实例如下
图示。

程序设计参考(仅提供主要数据结构和部分程序参考,具体实施可自行设计)
(1)进程控制块相关数据结构。

例:
typedef struct _Pcb{
int pid; /* 进程ID */
char name[20]; /* 进程名*/
int state; /* 进程状态*/
int priority; /* 进程优先级*/
int tArriving; /* 到达时间*/
int tOverall; /* 运行总时间*/
int tRunnng; /* 已运行时间*/
} Pcb;
typedef struct _PcbQueue{
Pcb *block; /* Pcb数据域*/
struct _PcbQueue *next; /* 指针域*/
} PcbQueue;
typedef struct _PPQueue{
PcbQueue *head;
PcbQueue *tail;
} PPQueue;
typedef struct _GQueues{
PPQueue qFree; /* 空余队列*/
PPQueue qReady; /* 就绪队列*/
} GQueues;
/* 分配的最大空余PCB块个数*/
#define MAX_PCB_NUM 10
extern Pcb pcbBlock[MAX_PCB_NUM];
(2)维护PCB队列。

例:
/* 初始化PCB块和空余队列*/
int InitGQueues(GQueues *gq);
/* 释放内存*/
void DestroyGQueues(GQueues *gq) ;
/* 分配PCB内存块*/
int allocPcb(GQueues *gq, int pid, int tServing, int tArriving);
/* 回收PCB块*/
void collectPcb(GQueues *gq);
/* RR算法*/
void invokeRR(PPQueue *ready, int flag);
/* SPF算法*/
void invokeSpf(PPQueue *ready);
/* 返回执行进程的pid, -1表示无就绪进程*/
int running(PcbQueue *head);
/* 队头进程是否结束,1为运行完毕*/
int finishReadyHead(GQueues *gq);
(3)主程序。


/* 初始化PCB块和空余队列*/
InitGQueues(gq);
/* 根据录入进程数据,分配PCB */
allocPcb(gq, i, tServing, tArriving);
/* 输入进程调度方式*/
do {
/* 调度就绪队列*/
switch (nSchedule)
{
case RR:
invokeRR(&(gq->qReady), RRflag);
break;
case SPF:
invokeSpf(&(gq->qReady));
break;
default:
break;
}
/* 运行*/
pid = running(gq->qReady.head);
/* 就绪队列的队头是否运行完毕?*/
RRflag = finishReadyHead(gq);
/* 是否全部运行完毕?*/
if (gq->qReady.head == NULL)
break;
} while (1);
/* 结束实验,清理内存*/
DestroyGQueues(gq);
实验开设方式
本实验开设方式为个人实验;授课、上机共4学时。

实验二存储分配――首次适应算法设计●实验所属系列:操作系统课程实验
●实验对象:本科
●相关课程及专业:计算机操作系统,计算机专业
●实验类型:配套上机
●实验时数:4学时
实验目的
通过编写和调试存储管理的首次适应算法以加深对存储管理方案的理解。

实验内容
实现内存分配首次适应算法,并通过输入一组内存请求与回收序列验证该算法执行情况。

用如下请求和释放序列验证该算法执行情况。

内存总空间为1000k,请求100k――>请求240k――>请求64k――>请求256k――>释放240k――>释放100k――>请求75k――>释放64k――>释放75k――>释放256k
试输出每次请求和释放动作产生后的内存状态。

实验要求
实验前要做好充分准备,包括程序清单、调试步骤、调试方法、以及对程序结果的分析等。

程序设计参考(仅提供主要数据结构和部分程序参考,具体实施可自行设计)
(1)主要数据结构。

例:
typedef struct _memorySpace
{
int size; //内存大小
int state; //0表示空闲,1表示已经装入作业
int taskID; //装入的作业ID
struct _memorySpace *next;
}memorySpace;
(2)主要函数。

例:
void *initMemeory(int size); //初始化
void manageMemory(memorySpace *memoryBlock); //选择操作类型
void displayMemory(memorySpace *memoryBlock); //显示内存分配状态
void addTask(memorySpace *memoryBlock); //添加作业
void delTask(memorySpace *memoryBlock); //删除作业
(3)主程序。

例:
int main(int argc, char *argv)
{
int size;
memorySpace *memoryBlock;
printf("初始多大空间,请输入一个整数:\n");
scanf("%d", &size);
/* 初始化大小为size大小的内存空间 */
memoryBlock = (memorySpace *)initMemeory(size);
/* 进入操作 */
manageMemory(memoryBlock);
return 0;
}
实验开设方式
本实验开设方式为个人实验;授课、上机共4学时。

相关文档
最新文档