计算机操作系统实验报告(共享内存管理).doc_第1页
计算机操作系统实验报告(共享内存管理).doc_第2页
计算机操作系统实验报告(共享内存管理).doc_第3页
计算机操作系统实验报告(共享内存管理).doc_第4页
计算机操作系统实验报告(共享内存管理).doc_第5页
免费预览已结束,剩余9页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

数学与计算机科学系实验报告课程:计算机操作系统 地点:软件实验室二 时间: 2013年 5月 17 日学生姓名班级学号仪器编号组别同组姓名实验项目共享内存管理指导教师实验目的理解 Linux 关于共享内存的概念,掌握 Linux 支持进程间内存共享的系统调用。巩固掌握进程同步概念。实验要求使用共享内存来完成进程间通信。 要求建立一个利用共享内存机制的,关于经典同步问题 readers/writers 的解决方案。 writer 从用户处获得输入,然后将其写入共享内存,reader 从共享内存获取信息,然后再在屏幕上打印出来。实验环境Linux环境实验内容及实验结果请写出具体的实验步骤,并给出相应的实验结果,附上编写的程序及其运行结果截图!实验步骤:1。2. 3. #include #include #include #include #include #include #include #include #include /* The union for semctl may or may not be defined for us.This code,defined in linuxs semctl() manpage,is the proper way to attain it if necessary */#if defined (_GNU_LIBRARY_)& !defined (_SEM_SEMUN_UNDEFINED)/* union semun is defined by including */#else/* according to X/OPEN we have to define it ourselves */union semunint val;/* value for SETVAL */struct semid_ds *buf;/* buffer for IPC_STAT,IPC_SET */unsigned short int *array;/* array for GETALL,SETALL */struct seminfo *_buf;/* buffer for IPC_INFO */;#endif#define SHMDATASIZE1000#define BUFFERSIZE (SHMDATASIZE - sizeof(int)#define SN_READ 0#define SN_WRITE 1#define SN_LOCK 2int Semid = 0;void reader(int shmid);void writer(int shmid);int masterinit(void);char *standardinit(int shmid,int *semid);void delete(void);void sigdelete(int signum);void locksem(int semid,int semnum);void unlocksem(int semid,int semnum);void waitzero(int semid,int semnum);void write(int shmid,int semid,char *buffer);int mysemget(key_t key,int nsems,int semflg);int mysemctl(int shmid,int semnum,int cmd,union semun arg);int mysemop(int semid,struct sembuf *sops,unsigned nsops);int myshmget(key_t key,int size,int shmflg);void *myshmat(int shmid,const void *shmaddr,int shmflg);int myshmctl(int shmid,int cmd,struct shmid_ds *buf);int main(int argc,char *argv)char selection3;int shmid;/* 没有参数,则为 master */if(argc 2)shmid = masterinit();elseshmid = atoi(argv1);printf( do you want a writer(1) or reader(2) ?);fgets(selection,sizeof(selection),stdin);switch(selection0)case 1:writer(shmid); break;case 2:reader(shmid);break;default:printf( invalid choice, quit n);return 0;void reader(int shmid)int semid;char *buffer;buffer = standardinit(shmid,&semid);printf(n reader begin to run, and the id of share memory is %d, semaphore id is %d n,shmid,semid);while(1)printf(n wait for writer to input information .);fflush(stdout);locksem(semid,SN_WRITE);printf(finish n);printf( wait for locking semaphore SN_LOCK .);fflush(stdout);locksem(semid,SN_LOCK);printf(finish n);printf(received information: %s n,buffer);unlocksem(semid,SN_LOCK);unlocksem(semid,SN_READ);void writer(int shmid)int semid;char *buffer;buffer = standardinit(shmid,&semid);printf(writer begin to run,the id of share memory is %d, semaphore id is %dn,shmid,semid);while(1)char input3;printf(n menu n 1.send a message n);printf( 2.quit n);printf(input your choice(1-2):);fgets(input,sizeof(input),stdin);switch(input0)case 1:write(shmid,semid,buffer);break;case 2:exit(0);break;char *standardinit(int shmid,int *semid)void *shmdata;char *buffer;shmdata = myshmat(shmid,0,0);*semid = *(int *)shmdata;buffer = shmdata + sizeof(int);return buffer;int masterinit(void)union semun sunion;int semid,shmid;void *shmdata;/* 首先:我们要创建信号量 */semid = mysemget(IPC_PRIVATE,3,SHM_R|SHM_W);Semid = semid;/* 当进程离开时,删除信号量 */atexit(&delete);signal(SIGINT,&sigdelete);/* 信号量 SN_READ 初始化为 1(锁定),SN_WRITE 初始化为 0(未锁定)*/* 信号量 SN_LOCK 初始化为 1(锁定)*/ sunion.val = 1;mysemctl(semid,SN_READ,SETVAL,sunion);mysemctl(semid,SN_LOCK,SETVAL,sunion);sunion.val = 0;mysemctl(semid,SN_WRITE,SETVAL,sunion);/* 现在创建一块共享内存 */shmid = myshmget(IPC_PRIVATE,SHMDATASIZE,IPC_CREAT|SHM_R|SHM_W);/* 将该共享内存映射进进程的虚存空间 */shmdata = myshmat(shmid,0,0);/* 将该共享内存标志为已销毁的,这样在使用完毕后,将被自动销毁*/myshmctl(shmid,IPC_RMID,NULL);/* 将信号量的标识符写入共享内存,以通知其它的进程 */*(int *)shmdata = semid;printf(* begin to run, and semaphore id is %d n,shmid);return shmid;void delete(void)printf(n quit; delete the semaphore %d n,Semid);union semun senion;senion.val=0;if(mysemctl(Semid,0,IPC_RMID,senion) = -1)printf(Error releasing semaphore. n);void sigdelete(int signum)/* Calling exit will conveniently trigger the normal delete item. */exit(0);void locksem(int semid,int semnum)struct sembuf sb;sb.sem_num = semnum;sb.sem_op = -1;sb.sem_flg = SEM_UNDO;mysemop(semid,&sb,1);void unlocksem(int semid,int semnum)struct sembuf sb;sb.sem_num = semnum;sb.sem_op = 1;sb.sem_flg = SEM_UNDO;mysemop(semid,&sb,1);void waitzero(int semid,int semnum)struct sembuf sb;sb.sem_num = semnum;sb.sem_op = 0;sb.sem_flg = 0;/* No modification so no need to undo */mysemop(semid,&sb,1);void write(int shmid,int semid,char *buffer)printf(n wait for reader to read in information .);fflush(stdout);locksem(semid,SN_READ);printf(finish; wait for locking semaphore SN_LOCK.n);fflush(stdout);locksem(semid,SN_LOCK);printf(please input information:);fgets(buffer,BUFFERSIZE,stdin);unlocksem(semid,SN_LOCK);unlocksem(semid,SN_WRITE);int mysemget(key_t key,int nsems,int semflg)int retval;retval = semget(key,nsems,semflg);if(retval = -1)printf(semget key %d,nsems %d failed: %s ,key,nsems,strerror(errno);exit(255);return retval;int mysemctl(int semid,int semnum,int cmd,union semun arg)int retval;retval = semctl(semid,semnum,cmd,arg);if(retval = -1)printf(semctl semid %d,semnum %d,cmd %d failed: %s,semid,semnum,cmd,strerror(errno);exit(255); return retval;int mysemop(int semid,struct sembuf *sops,unsigned nsops)int retval;retval = semop(semid,sops,nsops);if(retval = -1)printf(semop semid %d (%d operations) failed: %s,semid,nsops,strerror(errno);exit(255);return retval;int myshmge

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论