资源描述:
《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