操作系统课程设计报告—PV操作
更新时间:2023-09-13 16:40:01 阅读量: 教学研究 文档下载
操作系统设计实验报告
—— PV操作
学院:计算机科学技术与通信工程学院
班级:计算机0501班
姓名:白璐 学号:3050603018 指导老师:牛德娇
2008年 1月18
1
日
一、操作系统课程设计题目
LINUX系统管理实践与进程控制、进程通信实现
进程通信题目:桌上有一只盘子,每次只能放入3只水果。爸爸专放苹果,妈妈专放橘子,一个儿子专等吃盘子中的橘子,一个女儿专等吃盘子中的苹果。用P,V操作实现爸爸、妈妈、儿子、女儿进程的同步控制,橘子用orange表示,苹果用apple表示,空用empty表示。
二、开发环境
LINUX环境
三、分析设计
(一)实验原理
1. 原理:
parents(包括father和mother)--> |+++|(缓冲区:存放3个水果)-->daughter和son。 Parents和daughter、son通过共享缓冲区进行通信,信号量用于对缓冲区互斥访问、对parents和daughter、son进行同步。
2.共有五个程序:control , father , mother,son,daughter.其中control是主控程序. control:实现对缓冲区的初始化,要最先执行,且只需要执行一次。
father:把一个苹果放入缓冲区:从屏幕输入一个字符串(32字节以内)。 Mother:把一个橘子放入缓冲区:从屏幕输入一个字符串(32字节以内)。 Son:从缓冲区取出一个橘子:从屏幕上输出一个字符串。
Daughter:从缓冲区取出一个苹果:从屏幕上输出一个字符串。
3.注意:信号量、共享缓冲区都是系统资源,其总个数是有上限的。每个资源的id在系统中唯一,并且系统不会主动释放它们,所以要小心使用,及时释放。 本程序中:control在执行一次后(成功执行),信号量、共享缓冲区就会分配。如果再执行它,control会提示资源已经分配,是否要释放它们?
如果键入y(Y),则资源释放,此后执行father,mother,son,daughter都会报错。当然也可以使用ipcs ipcrm 命令来查看或释放资源。
4.为了结构清晰,程序没有多余的输入或输出。在father,mother,son,daughter程序中适当的位置增加输出语句,和输入字符语句将程序暂停在某个位置,以观察运行的详细进程。
(二)虚拟机下linux挂载U盘
需要让你的虚拟机Guest OS(Linux)能自动识别U盘。 方法如下:
保持焦点在Linux上,插入U盘,这时宿主操作系统Windows会弹出“找到新设备的提示”,然后一步一步的点下一步,结束以后,就可以在linux使用fdisk -l /dev/sdb命令查看到/dev/sdb1。
2
在虚拟机识别出USB之后,用fdisk -l /dev/sdb或fdisk -l /dev/hdb查看,会看到U盘被识别为sdb1,使用mount命令挂载即可。先在/mnt建一个新的文件夹,例如usb。 则可通过:mount -t vfat /dev/sdb1 /mnt/usb挂载上U盘 卸载使用:umount /dev/sdb1
四、源程序
1.主控程序control.c
#include
#define SHMKEY 9075 /*共享存储区的键*/ #define SEMKEY_son 9084 #define SEMKEY_parents 9085 #define SEMKEY_daughter 9086
#define SEMKEY_MUTEX 9087 /*信号量数组的键*//*注意:上面的键在系统中必须唯一*/ #define BUFF_LEN 3 /*缓冲区可以存放3个产品*/
#define PRODUCT_LEN 10 /*每个产品是一个字符串:<=32字符*/
void set_sembuf_struct(struct sembuf *sem,int semnum, int semop,int semflg) {
/* 设置信号量结构 */ sem->sem_num=semnum; sem->sem_op=semop; sem->sem_flg=semflg; }
main() {
char *addr, end; int shmid;
int semid_parents, semid_daughter,semid_son, semid_mutex;/*信号量id*/ struct sembuf sem_tmp;
/*开辟共享存储区*/
if ((shmid = shmget(SHMKEY, BUFF_LEN * PRODUCT_LEN+4, 0777|IPC_CREAT|IPC_EXCL)) == -1) {
if (errno == EEXIST) {
printf(\
3
printf(\ scanf(\
if(end == 'y' || end == 'Y') {
/* 共享存储区、信号量并不随程序的结束而被删除,如果我们没删除的话, 可以用ipcs命令查看,用ipcrm删除 */
/*释放缓冲区*/
shmid = shmget(SHMKEY, BUFF_LEN * PRODUCT_LEN+4, 0777); if (shmctl(shmid,IPC_RMID,0) < 0) perror(\
/*同时释放信号量*/
semid_mutex = semget(SEMKEY_MUTEX,1, 0777);
semid_daughter = semget(SEMKEY_daughter,1, 0777); semid_parents = semget(SEMKEY_parents,1, 0777); semid_son = semget(SEMKEY_son,1, 0777); semctl(semid_mutex,0,IPC_RMID); semctl(semid_daughter,0,IPC_RMID); semctl(semid_parents,0,IPC_RMID); semctl(semid_son,0,IPC_RMID); } } else
printf(\ return -1; }
addr = (char*)shmat(shmid, 0, 0);/*连接缓冲区*/ memset(addr, 0, BUFF_LEN * PRODUCT_LEN+2); shmdt(addr); /*离开缓冲区*/
/*创建3个信号量:1个用于对缓冲区互斥,2个用于生产者、消费者同步*/
if((semid_mutex = semget(SEMKEY_MUTEX,1, 0777|IPC_CREAT|IPC_EXCL))==-1) {
if (errno == EEXIST)
printf(\ else
printf(\ return -1; }
if((semid_daughter = semget(SEMKEY_daughter,1, 0777|IPC_CREAT|IPC_EXCL))==-1) {
if (errno == EEXIST)
4
printf(\ else
printf(\ return -1; }
if((semid_parents = semget(SEMKEY_parents,1, 0777|IPC_CREAT|IPC_EXCL))==-1) {
if (errno == EEXIST)
printf(\ else
printf(\ return -1; }
if((semid_son = semget(SEMKEY_son,1, 0777|IPC_CREAT|IPC_EXCL))==-1) {
if (errno == EEXIST)
printf(\ else
printf(\ return -1; }
/*给信号量赋初值*/
set_sembuf_struct(&sem_tmp, 0, 3, 0);/*BUdaughterFF_LEN*/ semop(semid_parents, &sem_tmp,1);
set_sembuf_struct(&sem_tmp, 0, 0, 0);/*0*/ semop(semid_daughter, &sem_tmp,1);
set_sembuf_struct(&sem_tmp, 0, 0, 0);/*0*/ semop(semid_son, &sem_tmp,1);
set_sembuf_struct(&sem_tmp, 0, 1, 0);/*1*/ semop(semid_mutex, &sem_tmp,1);
return 0; }
2. 父亲:father.c
#include
5
正在阅读:
操作系统课程设计报告—PV操作09-13
VB3124仓库管理系统203-05
音乐欣赏彼得与狼教案08-13
5岁以下儿童死亡监测制度(2)06-07
2011理论热点面对面-从怎么看到怎么办(官方下载版)(全)06-04
社会责任自我评估工具(中文版)03-05
油气田动态储量计算03-05
广东省第六届中小学音乐美术教师(DOC)03-05
归去来兮辞-教师案导学案03-05
- 公务员上岸同学告诉你,怎样走出面试中常见的十大误区
- 作表率,我们怎么办(办公室主任)
- 乘务员安全责任书
- 增员面试流程
- 河南省焦作市规模以上租赁和商务服务业企业应付职工薪酬数据洞察报告2019版
- 最新4社区工作者面试题
- 个人简历表
- 男教工体检必检项目
- 河南省兰考县规模以上租赁和商务服务业企业应付职工薪酬数据洞察报告2019版
- 兼职译员测试稿
- 河南省开封市规模以上租赁和商务服务业企业应付职工薪酬数据洞察报告2019版
- 永州职业技术学院校园总体规划-永州职业学院
- 最新5、培训科长笔试题(答案)
- 2019雅商酒店境外人员登记培训稀有资料,不可错过
- 小学教师求职简历范文
- 红酒知识与礼仪
- 春节给领导拜年的短信拜年词
- 2019年上半年中小学教师资格证结构化面试真题1
- 20XX年县干部培训工作目标
- 硬笔试听课
- 操作系统
- 课程
- 操作
- 报告
- 设计
- 保安岗位职责制度
- 数学人教版七年级上册〈有理数大小的比较〉
- 2014年物流师考试该注意哪些每日一讲(8月19日)
- 财务分析案例集1(实用)
- 湘教版高中地理必修三2.5矿产资源合理开发和区域可持续发展 - 以德国鲁尔区为例精编作业
- 网络编程文件传输实验报告
- 基于PLC系统下的三层楼电梯控制系统设计与调试
- 最新精品高考历史一轮复习高频考点专攻练十近代中国的新方向与近代化的曲折发展 - - 1919 - 1949年人民版
- 医用冷疗项目可行性研究报告 - 图文
- C语言调试时出现的错误及调整方法
- 2018全球与中国市场意大利面酱深度研究报告(目录) - 图文
- 电子电工类综合理论第一次月考试卷
- 省档案局关于印发《湖北省国家综合档案馆业务建设规范》的通知
- 数字电路与逻辑设计模拟题
- 中国广播专用喇叭行业市场调查研究报告(目录) - 图文
- 钙钛矿太阳能电池的制备
- 检察机关如何应对非法证据排除新规定
- 简讯第十期大漆完小 - 图文
- 专题7 电解质溶液和电离平衡
- 《数学教学生活化》开题报告 - 图文