2010龚滢峰实验二.doc

2010龚滢峰实验二.doc

ID:59265177

大小:98.50 KB

页数:6页

时间:2020-09-08

2010龚滢峰实验二.doc_第1页
2010龚滢峰实验二.doc_第2页
2010龚滢峰实验二.doc_第3页
2010龚滢峰实验二.doc_第4页
2010龚滢峰实验二.doc_第5页
资源描述:

《2010龚滢峰实验二.doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、集美大学计算机工程学院实验报告课程名称:操作系统班级:计算1013指导教师:李传目姓名:龚滢峰实验项目编号:实验二学号:实验项目名称:进程与线程——Linux进程与线程通讯实验成绩:一、目的深刻理解线程和进程的概念,掌握线程与进程在组成成分上的差别,以及与其相适应的通讯方式和应用目标。二、实验内容与设计思想1、以Linux系统进程和线程机制为背景,掌握fork()和clone()系统调用的形式和功能,以及与其相适应的高级通讯方式。由fork派生的子进程之间通过pipe通讯,由clone创建的线程之间通过共享内存通讯,对于后者需要考虑互斥问题。2

2、、以生产者/消费者问题为例,通过实验理解fork()和clone()两个系统调用的区别。程序要求能够创建4个进程或线程,其中包括两个生产者和两个消费者,生产者和消费者之间能够传递数据。三、实验使用环境RedHatEnterpriselinux5四、实验结果1.用pipe()创建一个管道文件,然后用fork()创建两个生产进程和两个消费进程,它们之间通过pipe()传递信息。#include"sys/types.h"#include"sys/file.h"#include"unistd.h"charr_buf[4];//读缓冲charw_buf[

3、4];//写缓冲intpipe_fd[2];pid_tpid1,pid2,pid3,pid4;intproducer(intid);intconsumer(intid);intmain(intargc,char**argv){if(pipe(pipe_fd)<0){printf("pipecreateerror");exit(-1);}else{printf("pipeiscreatedsuccessfully!");if((pid1=fork())==0)producer(1);if((pid2=fork())==0)producer

4、(2);if((pid3=fork())==0)consumer(1);if((pid4=fork())==0)consumer(2);}close(pipe_fd[0]);//需要加上这两句close(pipe_fd[1]);//否这会有读者或者写者永远等待inti,pid,status;for(i=0;i<4;i++)pid=wait(&status);exit(0);}intproducer(intid){printf("producer%disrunning!",id);close(pipe_fd[0]);inti=0;for(i=

5、1;i<10;i++){sleep(3);if(id==1)//生产者1strcpy(w_buf,"aaa");else//生产者2strcpy(w_buf,"bbb");if(write(pipe_fd[1],w_buf,4)==-1)printf("writetopipeerror");}close(pipe_fd[1]);printf("producer%disover!",id);exit(id);}intconsumer(intid){close(pipe_fd[1]);printf("producer%disrunn

6、ing!",id);if(id==1)//消费者1strcpy(w_buf,"ccc");else//消费者2strcpy(w_buf,"ddd");while(1){sleep(1);strcpy(r_buf,"eee");if(read(pipe_fd[0],r_buf,4)==0)break;printf("consumer%dget%s,whilethew_bufis%s",id,r_buf,w_buf);}close(pipe_fd[0]);printf("consumer%disover!",id);exit

7、(id);}2、测试程序#include"sched.h"#include"pthread.h"#include"stdio.h"#include"stdlib.h"#include"semaphore.h"intproducer(void*args);intconsumer(void*args);pthread_mutex_tmutex;sem_tproduct;sem_twarehouse;charbuffer[8][4];intbp=0;main(intargc,char**argv){pthread_mutex_init(&mutex,

8、NULL);sem_init(&product,0,0);sem_init(&warehouse,0,8);intclone_flag,arg,ret

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。