欢迎来到天天文库
浏览记录
ID:15156576
大小:37.00 KB
页数:5页
时间:2018-08-01
《《linux操作系统设计实践》实验二:进程通信》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、《Linux操作系统设计实践》实验二:进程通信实验目的:进一步了解和熟悉Linux支持的多种IPC机制,包括信号,管道,消息队列,信号量,共享内存。实验环境:redhat实验内容:(1)进程间命名管道通信机制的使用:使用命名管道机制编写程序实现两个进程间的发送接收信息。(2)进程间消息队列通信机制的使用:使用消息队列机制自行编制有一定长度的消息(1k左右)的发送和接收程序。 (3)进程间共享存储区通信机制的使用:使用共享内存机制编制一个与上述(2)功能相同的程序。并比较分析与其运行的快慢。实验代码验证:(1).使用命名管道机制编写程序实现两个进程间
2、的发送接收信息。#include#include#defineFIFO_FILE"MYFIFO"intmain(intargc,char*argv[]){FILE*fp;inti; if(argc<=1){printf("usage:%s",argv[0]);exit(1);}if((fp=fopen(FIFO_FILE,"w"))==NULL){printf("openfifofailed.");exit(1);}for(i=1;i3、i],fp)==EOF){printf("writefifoerror.");exit(1);}if(fputs("",fp)==EOF){printf("writefifoerror.");exit(1);}}fclose(fp);return0;}#include#include#include#include#include#defineFIFO_FILE"MYFIFO" intmain(){FILE*fp;charreadb4、uf[80]; if((fp=fopen(FIFO_FILE,"r"))==NULL){umask(0);mknod(FIFO_FILE,S_IFIFO5、0666,0);}else{fclose(fp);}while(1){if((fp=fopen(FIFO_FILE,"r"))==NULL){printf("openfifofailed.");exit(1);}if(fgets(readbuf,80,fp)!=NULL){printf("Receivedstring:%s",readbuf);fclose(fp);}else{if(fer6、ror(fp)){printf("readfifofailed.");exit(1);}}}return0;}实验结果:Server.c将client.c写入的字符输出。分析:client.c程序通过fopen(“MYPIO“,”w“)这个系统调用在当前目录下创建了一个名为MYPIPO的只写文件。将第一个以后的命令行参数,写进MYPIPO文件中;server.c程序首先使用fopen()系统调用试图打开MYPIPO文件,但是MYPIPO文件是只读文件,故调用失败,所以,接着调用umask(),和mknod()两个系统调用设置文件MYPIPO的属7、性,将文件改为有名管道类型,且是允许读写的文件(属主,属组,其他用户皆是)。最后通过fgets()这个系统调用将有名管道文件内的内容读到字符数组readbuf中,并显式。(2) 使用消息队列机制自行编制有一定长度的消息(1k左右)的发送和接收程序。#include#include#include#include#include#definekey1#definebuffersize1024intmain(){structSMSG{ longm8、type;charmtext[buffersize];}msg; intpid;intp; while((p=fork())==-1);if(p==0){sleep(5);pid=msgget(key,IPC_CREAT9、0600);msgrcv(pid,&msg,buffersize,1,0);printf("receivemsgis:%s",msg.mtext);msgctl(pid,IPC_RMID,0);}else{pid=msgget(key,IPC_CREAT10、0600);msg.mtype=1;strcpy(msg.mtext,"11、Thisisthemessagewhichtheparenthavesent!");while((msgsnd(pid,&
3、i],fp)==EOF){printf("writefifoerror.");exit(1);}if(fputs("",fp)==EOF){printf("writefifoerror.");exit(1);}}fclose(fp);return0;}#include#include#include#include#include#defineFIFO_FILE"MYFIFO" intmain(){FILE*fp;charreadb
4、uf[80]; if((fp=fopen(FIFO_FILE,"r"))==NULL){umask(0);mknod(FIFO_FILE,S_IFIFO
5、0666,0);}else{fclose(fp);}while(1){if((fp=fopen(FIFO_FILE,"r"))==NULL){printf("openfifofailed.");exit(1);}if(fgets(readbuf,80,fp)!=NULL){printf("Receivedstring:%s",readbuf);fclose(fp);}else{if(fer
6、ror(fp)){printf("readfifofailed.");exit(1);}}}return0;}实验结果:Server.c将client.c写入的字符输出。分析:client.c程序通过fopen(“MYPIO“,”w“)这个系统调用在当前目录下创建了一个名为MYPIPO的只写文件。将第一个以后的命令行参数,写进MYPIPO文件中;server.c程序首先使用fopen()系统调用试图打开MYPIPO文件,但是MYPIPO文件是只读文件,故调用失败,所以,接着调用umask(),和mknod()两个系统调用设置文件MYPIPO的属
7、性,将文件改为有名管道类型,且是允许读写的文件(属主,属组,其他用户皆是)。最后通过fgets()这个系统调用将有名管道文件内的内容读到字符数组readbuf中,并显式。(2) 使用消息队列机制自行编制有一定长度的消息(1k左右)的发送和接收程序。#include#include#include#include#include#definekey1#definebuffersize1024intmain(){structSMSG{ longm
8、type;charmtext[buffersize];}msg; intpid;intp; while((p=fork())==-1);if(p==0){sleep(5);pid=msgget(key,IPC_CREAT
9、0600);msgrcv(pid,&msg,buffersize,1,0);printf("receivemsgis:%s",msg.mtext);msgctl(pid,IPC_RMID,0);}else{pid=msgget(key,IPC_CREAT
10、0600);msg.mtype=1;strcpy(msg.mtext,"
11、Thisisthemessagewhichtheparenthavesent!");while((msgsnd(pid,&
此文档下载收益归作者所有