- 1、本文档共9页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
城院操作系统实验报告_实验八
浙江大学城市学院实验报告
课程名称 操作系统原理实验
实验项目名称 实验八 进程通信——管道
学生姓名 专业班级 学号
实验成绩 指导老师(签名 ) 日期
注意:
务请保存好各自的源代码,已备后用。
请上传到BB平台。
一. 实验目的和要求了解Linux系统的进程间通信机构(IPC);
理解Linux关于的概念;
掌握Linux支持的系统调用管道的使用;
巩固进程同步概念。
用系统调用pipe( )并发进程的无管道通信观察程序运行结果,并分析原因。假定系统有三个并发进程readmove和print共享缓冲器B1和B2。进程read负责从输入设备上读信息每读出一个记录后把它存放到缓冲器B1中进程move从缓冲器B1中取出一记录加工后存入缓冲器B2。进程print将B2中的记录取出打印输出缓冲器B1和B2每次只能存放一个记录。要求三个进程协调完成任务使打印出来的与读入的记录的个数次序完全一样。( )打开两个管道,如图 22所示,实现三个进程之间的同步。
程序源码:
#include unistd.h
#include signal.h
#include stdio.h
#include semaphore.h
#include fcntl.h
int pid1,pid2;
/*sem_t *S1;
sem_t *S2;
sem_t *S3;
sem_t *S4;*/
//sem_t S1;
//sem_t S2;
//sem_t S3;
//sem_t S4;
int valp;
main( )
{
/* S1=sem_open(A,O_CREAT,0644,1);
S2=sem_open(B,O_CREAT,0644,0);
S3=sem_open(C,O_CREAT,0644,0);
S4=sem_open(D,O_CREAT,0644,1);*/
// sem_init(S1,0,1);
// sem_init(S2,0,0);
// sem_init(S3,0,0);
// sem_init(S4,0,1);
int fd1[2];
int fd2[2];
char pipe1[100],pipe2[100],pipe3[100];
pipe(fd1); /*创建一个管道*/
pipe(fd2);
while ((pid1=fork( )) == -1);
if(pid1 == 0)
{
while ((pid2=fork( )) == -1);
if(pid2==0)
{
while(1)
{
// S1=sem_open(A,O_EXCL);
// sem_wait(S1);
lockf(fd1[1],1,0);
/*把输出串放入数组outpipe中*/
printf(process1 is sending message to pipe1\n);
sprintf(pipe1,%d,rand());
write(fd1[1],pipe1,50); /*向管道写长为50字节的串*/
lockf(fd1[1],0,0);
// printf(1111111111\n);
// S2=sem_open(B,O_EXCL);
// sem_post(S2);
// printf(22222222222\n);
}
}
else
{
while(1)
{
//sem_open(const char *name,int oflag,mode_t mode,unsigned int value);
// printf(33333333333\n);
// S2=sem_open(B,O_EXCL);
// sem_wait(S2);
// printf(44444444444\n);
// S4=sem_open(D,O_EXCL);
// sem_wait(S4);
printf(pro
文档评论(0)