操作系统实验报告
目录
目录
实验一
一、实验结果
实验二 使用信号量实现进程互斥与同步
一、实验结果
1. 使用信号量实现有限缓冲区的生产者和消费者问题
2. 使用信号量实现读进程具有优先权的读者和写者问题
实验三 死锁和预防
一、实验要求
二、实验内容
三、实验结果
实验四 内存管理
一、实验要求
二、实验内容
三、实验结果
实验五 处理器调度
一、实验要求
二、实验内容
三、实验结果
实验六 文件管理
一、实验要求
二、实验内容
三、实验结果
实验一
一、实验结果
在终端提供的Linux环境下,使用gcc编译器运行程序
结果如下
从输出结果可以看出,父进程先执行,然后创建了两个子进程。两个子进程同时在执行,并打印出正在执行的信息。接着,父进程将两个子进程杀死,最后父进程结束。
整个程序运行结果表明了进程同步的概念和实现方式,特别是父进程和子进程的关系,以及父进程对子进程的控制。
实验二 使用信号量实现进程互斥与同步
一、实验结果
1. 使用信号量实现有限缓冲区的生产者和消费者问题
在Linux环境下使用gcc编译器来将C语言程序编译成可执行文件(即exec文件)。
步骤如下:
(1)创建C源代码文件:首先,创建一个C语言源代码文件,生产者与消费者.c,并在其中编写程序代码。
(2)使用GCC编译器编译源代码文件:在终端中输入了以下命令
gcc /Users/peach/Desktop/操作系统实验/生产者与消费者/生产者与消费者.c
-o program
其中-o选项后的program是生成的可执行文件的名称,而生产者与消费者.c 是我编写的源代码文件名及路径。
(3)运行可执行文件:终端中输入了以下命令运行生成的可执行文件:
./program
结果如下
根据输出结果,可以看出生产者和消费者线程已经在正确地工作了。首先,生产者线程生产了编号为0的物品,并将其放入缓冲区的第一个位置。然后,消费者线程从缓冲区中取出编号为0的物品,并在每个循环中从缓冲区中取出下一个物品,直到缓冲区为空。
接下来,生产者线程继续生产物品,并将它们依次放入缓冲区。一旦缓冲区已满,生产者线程就会等待,直到有空余的槽位可用。当消费者线程消费了一些物品后,缓冲区就会变得不再满,这时生产者线程就会被唤醒,并开始继续生产物品。
在本例中,生产者线程总共生产了19个物品,消费者线程总共消费了18个物品。这是因为,在生产者线程生产第19个物品之前,缓冲区已经满了,导致生产者线程进入休眠状态,直到消费者线程消费掉一些物品并释放出空余的槽位为止。
2. 使用信号量实现读进程具有优先权的读者和写者问题
操作步骤同1,文件路径如下
/Users/peach/Desktop/操作系统实验/读者写者/读者写者/main.c
Linux环境下使用gcc编译器得到的运行结果如下:
现在对运行结果和执行过程作出一定的分析
初始状态,共有5个读者和2个写者线程,且共享数据的初值为0。
Writer 0 writes: 0
Reader 0 reads: 0
Reader 1 reads: 0
Reader 0 reads: 0
Reader 2 reads: 0
Reader 0 reads: 0
Reader 3 reads: 0
Reader 0 reads: 0
Reader 4 reads: 0
Reader 0 reads: 0
写者线程1开始执行,将共享数据的值改为1,并唤醒所有等待该数据的线程。
Writer 1 writes: 1
读者线程0开始执行,读取到共享数据的值为1,然后释放读者锁。
Reader 0 reads: 1
其他4个读者线程依次获得读者锁,并读取到共享数据的值为1,然后释放读者锁。
Reader 1 reads: 1
Reader 2 reads: 1
Reader 3 reads: 1
Reader 4 reads: 1
写者线程2开始执行,由于此时有读者线程持有读者锁,因此该写者线程需要等待所有读者线程完成读操作后才能进行写操作,即读者优先。
Writer 2 writes: 2
读者线程0开始执行,读取到共享数据的值为2,然后释放读者锁。
Reader 0 reads: 2
其他4个读者线程依次获得读者锁,并读取到共享数据的值为2,然后释放读者锁。
Reader 2 reads: 2
Reader 3 reads: 2
Reader 4 reads: 2
Reader 1 reads: 2
写者线程0开始执行,将共享数据的值改为0,并唤醒所有等待该数据的线程。
Writer 0 writes: 0
读者线程1开始执行,读取到共享数据的值为0,然后释放读者锁。
Reader 1 reads: 0
其他4个读者线程依次获得读者锁,并读取到共享数据的值为0,然后释放读者锁。
Reader 2 reads: 0
Reader 3 reads: 0
Reader 4 reads: 0
Reader 1 reads: 0
实验三 死锁和预防
一、实验要求
加深对银行家算法的理解。
二、实验内容
给出进程需求矩阵 C、资源向量 R 以及一个进程的申请序列。
使用进程启动拒绝和资源分配拒绝(银行家算法)模拟该进程组的执行情况。 要求:
1. 初始状态没有进程启动
2. 计算每次进程申请是否分配?如:计算出预分配后的状态情况(安全状 态、不安全状态),如果是安全状态,输出安全序列。
3. 每次进程申请被允许后,输出资源分配矩阵 A 和可用资源向量 V。 4. 每次申请情况应可单步查看,如:输入一个空格,继续下个申请。
三、实验结果
在Linux环境下使用gcc编译器完成本次实验
测试结果如下
序列判断
输入资源需求量
结束运行
实验四 内存管理
一、实验要求
熟悉存储器管理系统的设计方法,加深对所学各种内存管理方案的了解。
二、实验内容
随机给出一个页面执行序列, 如:1,5,3,4,2,1,3,4,5,7,9 … … .要求计算以下几种 置换算法的缺页数、缺页率和命中率。
1. 先进先出算法 FIFO(First In First Out)
2. 最近最少使用算法 LRU(Least Recently Used)
3. 最佳置换算法 OPT(Optimal)
三、实验结果
在Linux环境下使用gcc编译器完成本次实验
1.首先用户输入数据
包括计算机可以分配给进程的页面数量、执行过程中访问页面的序列及序列长度。
2.分别利用FIFO、LRU、OPT算法进行缺页数、缺页率和命中率的计算。
经分析,运行结果与实际一致。
实验五 处理器调度
一、实验要求
熟悉使用各种单处理器调度(短程调度)的各种算法。
二、实验内容
随机给出一个进程调度实例,如:
进程 | 到达时间 | 服务时间 |
A | 0 | 3 |
B | 2 | 6 |
C | 4 | 4 |
D | 6 | 5 |
E | 8 | 2 |
模拟进程调度, 给出按照算法先来先服务(FCFS)、轮转(RR)(q=1)、最短进 程优先(SPN)进行调度各进程的完成时间、周转时间、响应比的值。
三、实验结果
1.在终端提供的Linux环境下使用gcc编译器完成本次实验
2.进行进程初始化
3.选择调度算法
(1)FCFS算法
(2)短进程优先算法
(3)高优先级算法
(4)时间片轮转算法
省略轮转过程……
实验六 文件管理
一、实验要求
熟悉二级存储管理中的文件分配策略。
二、实验内容
给出一个磁盘块序列: 1 、2 、3 、…… 、500,初始状态所有块为空的,每块的大小为 2k。选择使用位表、链式空闲区、索引和空闲块列表四种算法之一来管理空闲块。对于基于块的索引分配执行以下步骤:
1. 随机生成 2k- 10k的文件 50 个, 文件名为 1.txt、2.txt 、……、50.txt,按照上述算法存储到模拟磁盘中。
2. 删除奇数.txt(1.txt 、3.txt 、 …… 、49.txt)文件
3. 新创建 5 个文件(A.txt 、B.txt 、C.txt 、D.txt 、E.txt),大小为:7k 、5k、 2k 、9k 、3.5k,按照与步骤 1 相同的算法存储到模拟磁盘中。
4. 给出文件 A.txt 、B.txt 、C.txt 、D.txt 、E.txt 的文件分配表和空闲区块的状态。
三、实验结果
在终端提供的Linux环境下使用gcc编译器运行程序
运行结果如下
文件分配
相关文章:

操作系统实验报告
目录 目录 实验一 一、实验结果 实验二 使用信号量实现进程互斥与同步 一、实验结果 1. 使用信号量实现有限缓冲区的生产者和消费者问题 2. 使用信号量实现读进程具有优先权的读者和写者问题 实验三 死锁和预防 一、实验要求 二、实验内容 三、实验结果 实验四 内…...

IPv6--ACL6(IPv6访问控制列表--基本ACL6配置)
ACL基本原理 ACL由一系列规则组成,通过将报文与ACL规则进行匹配,设备可以过滤出特定的报文。 ACL的组成 ACL编号: 在网络设备上配置ACL时,每个ACL都需要分配一个编号,称为ACL编号,用来标识ACL。不同分类的ACL编号范围不同,这个后面具体讲。 规则: 前面提到了,一个AC…...

C和指针课后答案
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、pandas是什么?二、使用步骤 1.引入库2.读入数据总结 前言 第八章课后答案 提示:以下是本篇文章正文内容,下面案例可供参…...

C语言——大头记单词
归纳编程学习的感悟, 记录奋斗路上的点滴, 希望能帮到一样刻苦的你! 如有不足欢迎指正! 共同学习交流! 🌎欢迎各位→点赞 👍 收藏⭐ 留言📝 每一发奋努力的背后,必有加…...

根据自己修改后的容器制作镜像并上传docker hub
要将自己的镜像上传到Docker Hub,可以按照以下步骤进行操作: 首先,确保已经在本地构建好了需要上传的 Docker 镜像。如果还没有构建,可以使用 docker build 命令来创建镜像。 登录到 Docker Hub 账号。打开终端或命令提示符&…...

Maven 基础安装配置及使用
大家好我是苏麟 , 今天聊聊Maven . Maven Maven , 是Apache公司下基于Java开发的开源项目 . 我们构建一个项目需要用到很多第三方的类库,需要引入大量的jar包。一个项目Jar包的数量之多往往让我们瞠目结舌,并且Jar包之间的关系错综复杂,一…...

redis 持久化机制
client redis[内存] -----> 内存数据- 数据持久化-->磁盘 Redis官方提供了两种不同的持久化方法来将数据存储到硬盘里面分别是: RDB 快照(Snapshot) AOF (Append Only File) 只追加日志文件 1 快照(Snapshot) 1. 特点 这种方式可以将某一时刻的所有数据都写入硬盘中…...

MySQL(视图,存储函数,存储过程)
作业1: 作业实现: 首先创建学生表,课程表,以及学生选课表。 CREATE TABLE Student (Sno INT PRIMARY KEY,Sname VARCHAR(20) NOT NULL,Ssex CHAR(1) CHECK (Ssex IN (男, 女)),Sage INT,SDept VARCHAR(20) DEFAULT 计算机 );CRE…...

rockchip 平台 linux FIT 打包格式介绍
1 基础介绍 FIT(flattened image tree)是U-Boot⽀持的⼀种新固件类型的引导⽅案,⽀持任意多个image打包和校 验。FIT 使⽤ its (image source file) ⽂件描述image信息,最后通过mkimage⼯具⽣成 itb (flattened image tree blob) …...

虚拟机安装宝塔的坑
问题: 在虚拟机中centos7和centos8中安装宝塔之后,无法访问面板。 解决: 1.先关闭防火墙(如果本机能够ping通相关端口,则不用关闭防火墙) 2.最新的宝塔会自动开启ssl协议,需要手动关闭。…...

Ubuntu使用QtCreator + CMake 开发C/C++程序
平台 OS: Ubuntu 20.04 cmake: 3.16.3 IDE: Qt Creator 4.11.1 Based on Qt 5.14.1 (GCC 5.3.1 20160406 (Red Hat 5.3.1-6), 64 bit) Built on Feb 5 2020 12:48:30 From revision b2ddeacfb5 Copyright 2008-2019 The Qt Company Ltd. All rights reserved. The program …...

【分布式监控】zabbix与grafana连接
1.在zabbix- server服务端安装grafana,并启动服务 先在官网下载软件 https://grafana.com/grafana/download/9.4.7?editionenterprise&pggraf&plcmtdeploy-box-1#可以翻译成中文介绍,很详细的教程 yum install -y https://dl.grafana.com/ent…...

02-编程猜谜游戏
本章通过演示如何在实际程序中使用 Rust,你将了解 let 、 match 、方法、关联函数、外部crate等基础知识。 本章将实现一个经典的初学者编程问题:猜谜游戏。 工作原理如下:程序将随机生成一个介于 1 和 100 之间的整数。然后,程序…...

Web3解密:区块链技术如何颠覆传统互联网
随着区块链技术的崛起,Web3正逐渐成为新一代互联网的代名词。它不再依赖中心化的权威机构,而是通过去中心化、透明、安全的特性,为用户带来更为开放和公正的互联网体验。本文将深入解密Web3,揭示区块链技术如何颠覆传统互联网的基…...

java小项目:简单的收入明细记事本,超级简单(不涉及数据库,通过字符串来记录)
一、效果 二、代码 2.1 Acount类 package com.demo1;public class Acount {public static void main(String[] args) {String details "收支\t账户金额\t收支金额\t说 明\n"; //通过字符串来记录收入明细int balance 10000;boolean loopFlag true;//控制循…...

域环境权限提升
Windows系统配置错误 在Windows系统中,攻击者通常会通过系统内核溢出漏来提权,但是如果碰到无法通过系统内核溢出漏洞法国提取所在服务器权限的情况,就会系统中的配置错误来提权。Windows系统中常见哦欸之错误包括管理员凭证配置错误&#x…...

【Debian】非图形界面Debian10.0.0安装xfce和lxde桌面
一、安装 1. Debian10.0.0安装xfce桌面 sudo apt update sudo apt install xfce4 startxfce4 2. Debian10.0.0安装lxde桌面 sudo apt-get install lxde安装后重启电脑。 二、说明 XFCE、LXDE 和 GNOME 是三个流行的桌面环境,它们都是为类 Unix 操作系统设计…...

极狐GitLab 线下『 DevOps专家训练营』成都站开班在即
成都机器人创新中心联合极狐(GitLab)隆重推出极狐GitLab DevOps系列认证培训课程。该课程主要面向使用极狐GitLab的DevOps工程师、安全审计人员、系统运维工程师、系统管理员、项目经理或项目管理人员,完成该课程后,学员将达到DevOps的专家级水平&#x…...

片外存储器_FLASH的页、扇区、块介绍
目录标题 1、什么是FLASH存储器?2、Flash中页、扇区、块是什么意思?有什么区别?2.1、芯片内部框图2.2、页2.3、扇区2.4、块2.5、包含示意图 3、使用FLASH 时候,必须知道的事。 1、什么是FLASH存储器? FLASH属于广义的ROM&#x…...

Python——字符串的基本操作
⼀、 创建 s1 lenovo s2 "QF" s3 """hello lenovo""" s4 hello 亮 s5 """hello shark """ s6 hello world ⼆、简单使⽤ 1.\ 转义符 testimony This shirt doesn\t fit me words hello \ns…...

【cuda】四、基础概念:Cache Tiled 缓存分块技术
缓存分块是一种内存优化技术,主要用于提高数据的局部性(Locality),以减少缓存未命中(Cache Miss)的次数。在现代计算机体系结构中,处理器(CPU)的速度通常比内存快得多。因…...

[C#]winform部署openvino官方提供的人脸检测模型
【官方框架地址】 https://github.com/sdcb/OpenVINO.NET 【框架介绍】 OpenVINO(Open Visual Inference & Neural Network Optimization)是一个由Intel推出的,针对计算机视觉和机器学习任务的开源工具套件。通过优化神经网络ÿ…...

Java中对日期的处理
Java中对日期的处理 这个案例主要掌握: 1.怎么获取系统当前时间 2.String-->Date 3.Date-->String Import java.text.SimpleDateFormat; Import java.util.Date; public class DateTest01{ public static void main(String[] args) throws Exception{ //获取…...

【Linux install】Ubuntu和win双系统安装及可能遇到的所有问题
文章目录 1.前期准备1.1 制作启动盘1.2关闭快速启动、安全启动、bitlocker1.2.1 原因1.2.2 进入BIOSshell命令行进入BIOSwindows设置中高级启动在开机时狂按某个键进入BIOS 1.2.3 关闭Fast boot和Secure boot 1.3 划分磁盘空间1.3.1 查看目前的虚拟内存大小 2.开始安装2.1 使用…...

Helm Dashboard — Kubernetes 中管理 Helm 版本的 GUI
Helm Dashboard 通过提供图形用户界面,使在 Kubernetes 中管理 Helm 版本变得更加容易,这是许多开发人员所期望的。它可用于在 Kubernetes 中创建、部署和更新应用程序的版本,并跟踪其状态。 本文将探讨 Helm Dashboard 提供的特性和优势&am…...

【Guava笔记01】Guava Cache本地缓存的常用操作方法
这篇文章,主要介绍Guava Cache本地缓存的常用操作方法。 目录 一、Guava Cache本地缓存 1.1、引入guava依赖 1.2、CacheBuilder类 1.3、Guava-Cache使用案例...

Flink(十三)【Flink SQL(上)SqlClient、DDL、查询】
前言 最近在假期实训,但是实在水的不行,三天要学完SSM,实在一言难尽,浪费那时间干什么呢。SSM 之前学了一半,等后面忙完了,再去好好重学一遍,毕竟这玩意真是面试必会的东西。 今天开始学习 Flin…...

Labview局部变量、全局变量、引用、属性节点、调用节点用法理解及精讲
写本章前想起题主初学Labview时面对一个位移台程序,傻傻搞不清局部变量和属性节点值有什么区别,概念很模糊。所以更新这篇文章让大家更具象和深刻的去理解这几个概念,看完记得点赞加关注喔~ 本文程序源代码附在后面,大家可以自行下…...

openssl3.2 - 官方demo学习 - signature - EVP_ED_Signature_demo.c
文章目录 openssl3.2 - 官方demo学习 - signature - EVP_ED_Signature_demo.c概述笔记END openssl3.2 - 官方demo学习 - signature - EVP_ED_Signature_demo.c 概述 ED25519 签名/验签算法, 现在是最好的. 产生ED25519私钥/公钥 用私钥对明文签名, 得到签名数据 用公钥对明文…...

AI辅助编程工具—Github Copilot
一、概述 Copilot是一种基于Transformer模型的神经网络,具有12B个参数。是GitHub和OpenAPI共同开发的编程辅助工具。GitHubCopilot是一款由人工智能驱动的结对编程编辑器,旨在帮助开发人员更加高效地工作。它利用OpenAICodex技术,将开发…...