- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
操作系统课程设计报告—pv操作
操作系统设计实验报告
—— PV操作
学院:计算机科学技术与通信工程学院
班级:计算机0501班
姓名:白璐
学号:3050603018
指导老师:牛德娇
2008年 1月18 日
一、操作系统课程设计题目
LINUX系统管理实践与进程控制、进程通信实现
进程通信题目:桌上有一只盘子,每次只能放入3只水果。爸爸专放苹果,妈妈专放橘子,一个儿子专等吃盘子中的橘子,一个女儿专等吃盘子中的苹果。用P,V操作实现爸爸、妈妈、儿子、女儿进程的同步控制,橘子用orange表示,苹果用apple表示,空用empty表示。
二、开发环境
LINUX环境
三、分析设计
(一)实验原理
原理:
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。
在虚拟机识别出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 sys/types.h
#include sys/ipc.h
#include sys/shm.h
#include sys/sem.h
#include errno.h
#include string.h
#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;
in
文档评论(0)