如果您无法下载资料,请参考说明:
1、部分资料下载需要金币,请确保您的账户上有足够的金币
2、已购买过的文档,再次下载不重复扣费
3、资料包下载后请先用软件解压,在使用对应软件打开
《Linux操作系统设计实践》实验二:进程通信实验目的:进一步了解和熟悉Linux支持的多种IPC机制,包括信号,管道,消息队列,信号量,共享内存。实验环境:redhat实验内容:(1)进程间命名管道通信机制的使用:使用命名管道机制编写程序实现两个进程间的发送接收信息。(2)进程间消息队列通信机制的使用:使用消息队列机制自行编制有一定长度的消息(1k左右)的发送和接收程序。(3)进程间共享存储区通信机制的使用:使用共享内存机制编制一个与上述(2)功能相同的程序。并比较分析与其运行的快慢。实验代码验证:(1).使用命名管道机制编写程序实现两个进程间的发送接收信息。#include<stdio.h>#include<stdlib.h>#defineFIFO_FILE"MYFIFO"intmain(intargc,char*argv[]){FILE*fp;inti;if(argc<=1){printf("usage:%s<pathname>\n",argv[0]);exit(1);}if((fp=fopen(FIFO_FILE,"w"))==NULL){printf("openfifofailed.\n");exit(1);}for(i=1;i<argc;i++){if(fputs(argv[i],fp)==EOF){printf("writefifoerror.\n");exit(1);}if(fputs("",fp)==EOF){printf("writefifoerror.\n");exit(1);}}fclose(fp);return0;}#include<stdio.h>#include<stdlib.h>#include<sys/stat.h>#include<unistd.h>#include<linux/stat.h>#defineFIFO_FILE"MYFIFO"intmain(){FILE*fp;charreadbuf[80];if((fp=fopen(FIFO_FILE,"r"))==NULL){umask(0);mknod(FIFO_FILE,S_IFIFO|0666,0);}else{fclose(fp);}while(1){if((fp=fopen(FIFO_FILE,"r"))==NULL){printf("openfifofailed.\n");exit(1);}if(fgets(readbuf,80,fp)!=NULL){printf("Receivedstring:%s\n",readbuf);fclose(fp);}else{if(ferror(fp)){printf("readfifofailed.\n");exit(1);}}}return0;}实验结果:Server.c将client.c写入的字符输出。分析:client.c程序通过fopen(“MYPIO“,”w“)这个系统调用在当前目录下创建了一个名为MYPIPO的只写文件。将第一个以后的命令行参数,写进MYPIPO文件中;server.c程序首先使用fopen()系统调用试图打开MYPIPO文件,但是MYPIPO文件是只读文件,故调用失败,所以,接着调用umask(),和mknod()两个系统调用设置文件MYPIPO的属性,将文件改为有名管道类型,且是允许读写的文件(属主,属组,其他用户皆是)。最后通过fgets()这个系统调用将有名管道文件内的内容读到字符数组readbuf中,并显式。(2)使用消息队列机制自行编制有一定长度的消息(1k左右)的发送和接收程序。#include<stdio.h>#include<string.h>#include<sys/types.h>#include<sys/ipc.h>#include<sys/msg.h>#definekey1#definebuffersize1024intmain(){structSMSG{longmtype;charmtext[buffersize];}msg;intpid;intp;while((p=fork())==-1);if(p==0){sleep(5);pid=msgget(key,IPC_CREAT|0600);msgrcv(pid,&msg,buffersize,1,0);print