实验8-多线程“生产者消费者”实验.docx

上传人:scccc 文档编号:11450007 上传时间:2021-08-05 格式:DOCX 页数:9 大小:90.87KB
返回 下载 相关 举报
实验8-多线程“生产者消费者”实验.docx_第1页
第1页 / 共9页
实验8-多线程“生产者消费者”实验.docx_第2页
第2页 / 共9页
实验8-多线程“生产者消费者”实验.docx_第3页
第3页 / 共9页
实验8-多线程“生产者消费者”实验.docx_第4页
第4页 / 共9页
实验8-多线程“生产者消费者”实验.docx_第5页
第5页 / 共9页
点击查看更多>>
资源描述

《实验8-多线程“生产者消费者”实验.docx》由会员分享,可在线阅读,更多相关《实验8-多线程“生产者消费者”实验.docx(9页珍藏版)》请在三一文库上搜索。

1、实验8 多线程“生产者消费者”实验学生姓名: 李亚军 学 号: 6100412196 专业班级: 卓越计科121班 1实验目的“生产者消费者”问题是一个著名的同时性编程问题的集合。通过学习经典的“生产者消费者”问题的实验,读者可以进一步熟悉Linux中的多线程编程,并且掌握用信号量处理线程间的同步和互斥问题。2实验内容“生产者消费者”问题描述如下。有一个有限缓冲区和两个线程:生产者和消费者。他们分别不停地把产品放入缓冲区和从缓冲区中拿走产品。一个生产者在缓冲区满的时候必须等待,一个消费者在缓冲区空的时候也必须等待。另外,因为缓冲区是临界资源,所以生产者和消费者之间必须互斥执行。它们之间的关系如

2、图1所示。图1 生产者消费者问题描述这里要求使用有名管道(将在下一章介绍,可提前了解)来模拟有限缓冲区,并且使用信号量来解决“生产者消费者”问题中的同步和互斥问题。3实验步骤(1)信号量的考虑。这里使用3个信号量,其中两个信号量avail和full分别用于解决生产者和消费者线程之间的同步问题,mutex是用于这两个线程之间的互斥问题。其中avail表示有界缓冲区中的空单元数,初始值为N;full表示有界缓冲区中非空单元数,初始值为0;mutex是互斥信号量,初始值为1。(2)画出流程图。本实验流程图如图2所示。图2 “生产者消费者”实验流程图(3)编写代码本实验的代码中采用的有界缓冲区拥有3个

3、单元,每个单元为5个字节。为了尽量体现每个信号量的意义,在程序中生产过程和消费过程是随机(采取05s的随机时间间隔)进行的,而且生产者的速度比消费者的速度平均快两倍左右(这种关系可以相反)。生产者一次生产一个单元的产品(放入“hello”字符串),消费者一次消费一个单元的产品。/*producer-customer.c*/#include #include #include #include #include #include #include #include #define MYFIFO myfifo /* 缓冲区有名管道的名字 */#define BUFFER_SIZE 3 /* 缓冲区

4、的单元数 */#define UNIT_SIZE 5 /* 每个单元的大小 */#define RUN_TIME 30 /* 运行时间 */#define DELAY_TIME_LEVELS 5.0 /* 周期的最大值 */int fd;time_t end_time;sem_t mutex, full, avail; /* 3个信号量 */*生产者线程*/void *producer(void *arg) int real_write; int delay_time = 0; while(time(NULL) end_time) delay_time = (int)(rand() * DEL

5、AY_TIME_LEVELS/(RAND_MAX) / 2.0) + 1; sleep(delay_time); /*P操作信号量avail和mutex*/ sem_wait(&avail); sem_wait(&mutex); printf(nProducer: delay = %dn, delay_time); /*生产者写入数据*/ if (real_write = write(fd, hello, UNIT_SIZE) = -1) if(errno = EAGAIN) printf(The FIFO has not been read yet.Please try latern); e

6、lse printf(Write %d to the FIFOn, real_write); /*V操作信号量full和mutex*/ sem_post(&full); sem_post(&mutex); pthread_exit(NULL);/* 消费者线程*/void *customer(void *arg) unsigned char read_bufferUNIT_SIZE; int real_read; int delay_time; while(time(NULL) end_time) delay_time = (int)(rand() * DELAY_TIME_LEVELS/(R

7、AND_MAX) + 1; sleep(delay_time); /*P操作信号量full和mutex*/ sem_wait(&full); sem_wait(&mutex); memset(read_buffer, 0, UNIT_SIZE); printf(nCustomer: delay = %dn, delay_time); if (real_read = read(fd, read_buffer, UNIT_SIZE) = -1) if (errno = EAGAIN) printf(No data yetn); printf(Read %s from FIFOn, read_buf

8、fer); /*V操作信号量avail和mutex*/ sem_post(&avail); sem_post(&mutex); pthread_exit(NULL);int main() pthread_t thrd_prd_id,thrd_cst_id; pthread_t mon_th_id; int ret; srand(time(NULL); end_time = time(NULL) + RUN_TIME; /*创建有名管道*/ if(mkfifo(MYFIFO, O_CREAT|O_EXCL) 0) & (errno != EEXIST) printf(Cannot create

9、fifon); return errno; /*打开管道*/ fd = open(MYFIFO, O_RDWR); if (fd = -1) printf(Open fifo errorn); return fd; /*初始化互斥信号量为1*/ ret = sem_init(&mutex, 0, 1); /*初始化avail信号量为N*/ ret += sem_init(&avail, 0, BUFFER_SIZE); /*初始化full信号量为0*/ ret += sem_init(&full, 0, 0); if (ret != 0) printf(Any semaphore initia

10、lization failedn); return ret; /*创建两个线程*/ ret = pthread_create(&thrd_prd_id, NULL, producer, NULL); if (ret != 0) printf(Create producer thread errorn); return ret; ret = pthread_create(&thrd_cst_id, NULL, customer, NULL); if(ret != 0) printf(Create customer thread errorn); return ret; pthread_join(thrd_prd_id, NULL); pthread_join(thrd_cst_id, NULL); close(fd); unlink(MYFIFO); return 0;4 根据实验结果完成实验报告,写出实验总结。整个实验比较简单,但是开始老是在编译的时候出现sem_wait等未定义的错误,经上网查询得知c库没有使能semaphore的支持.,故而需要添加-lpthread参数。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 社会民生


经营许可证编号:宁ICP备18001539号-1