操作系统哲学家就餐问题课程设计C语言(共11页).doc
《操作系统哲学家就餐问题课程设计C语言(共11页).doc》由会员分享,可在线阅读,更多相关《操作系统哲学家就餐问题课程设计C语言(共11页).doc(11页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上题目: 用多线程同步方法解决哲学家就餐问题(Dining-Philosophers Problem)初始条件:1 操作系统:Linux2 程序设计语言:C语言3共有5个哲学家需用餐。只许4个哲学家入席且桌上有5支筷子。要求完成的主要任务: (包括课程设计工作量及其技术要求,以及说明书撰写等具体要求) 1技术要求:1)为每个哲学家产生一个线程,设计正确的同步算法2)每个哲学家取得一双筷子开始用餐后,即时显示“Dining”和该哲学家的自定义标识符以及餐桌上所有几位哲学家标识符及其所坐的位置。3)设定共有5个哲学家需用餐。每位用餐耗时10秒钟以上。4)多个哲学家须共享操作
2、函数代码。 2 设计说明书内容要求:1)设计题目与要求2)总的设计思想及系统平台、语言、工具等。3)数据结构与模块说明(功能与流程图)4)给出用户名、源程序名、目标程序名和源程序及其运行结果。(要注明存储各个程序及其运行结果的Linux主机IP地址和目录。)5)运行结果与运行情况(提示: (1)连续存储区可用数组实现。(2)编译命令可用:cc -lpthread -o 目标文件名源文件名(3)多线程编程方法参见附件。) 3. 调试报告:1) 调试记录2) 自我评析和总结上机时间安排:18周一 五 08:0 12:00 指导教师签名: 年 月 日系主任(或责任教师)签名: 年 月 日用多线程同步
3、方法解决哲学家就餐问题(Dining-Philosophers Problem)1设计题目与要求1.1设计题目描述:用多线程同步方法解决哲学家就餐问题(Dining-Philosophers Problem)1.2要求:1)为每个哲学家产生一个线程,设计正确的同步算法2)每个哲学家取得一双筷子开始用餐后,即时显示“Dining”和该哲学家的自定义标识符以及餐桌上所有几位哲学家标识符及其所坐的位置。3)设定共有5个哲学家需用餐。每位用餐耗时10秒钟以上。4)多个哲学家须共享操作函数代码。2总体设计思想及系统平台、语言、工具2.1总体设计思想哲学家就餐问题,即共有5个哲学家绕一个圆桌做在5个位置上
4、,他们每2个人中间有一只筷子,共5只筷子,只有当每个哲学家取得他左右两边的筷子时,哲学家才能开始就餐,其它时间,哲学家只能思考或等待筷子。为避免哲学家互相等待对方的筷子发生死锁,本次课程设计要求只许4个哲学家入席,以保证至少有一个哲学家能够进餐。本课程设计将room 作为信号量,将其初始化为4,以保证只允许4个哲学家同时入席就餐,这样就能保证至少有一个哲学家可以就餐。针对每个哲学家,通过共享操作函数代码,分别建立5个线程,以实现同步哲学家就餐,而申请进入餐厅的哲学家进入room 的等待队列,根据FIFO 的原则,总会进入到餐厅就餐,因此不会出现饿死和死锁的现象,针对5只筷子分别设置了5个互斥信
5、号量,以保证每只筷子每次只能被取得一次。2.2系统平台、语言及工具(1)操作系统:Linux(2)程序设计语言:C语言(3)工具:编辑工具Vi、编译器gcc3数据结构与模块说明线程创建函数pthread_create声明如下:#include int pthread_create (pthread_t *thread,pthread_attr_t *attr,Void* (*start_routine)(void *),void *arg);等待其它线程结束函数pthread_join声明如下: #include int pthread_join (pthread_t th,void *thr
6、ead_return); 信号量的数据类型为结构sem_t,它本质上是一个长整型的数。初始化信号量函数sem_init声明如下: #include sem_init (sem_t *sem, int pshared, unsigned int value);增加信号量值函数sem_post声明如下:#include Sem_post ( sem_t *sem );减少信号量值函数sem_wait声明如下#include Sem_wait ( sem_t *sem ); 主要数据结构声明:#define NUMBERS 5 /将哲学家人数NUMBERS定义为5sem_t chopsticsNUM
7、BERS /定义5只筷子的互斥信号量chopsticssem_t room /定义避免死锁的同步信号量room线程共享函数伪代码:void *Share(int i)think();wait(room); /请求入席进餐 wait(chopsticki); /请求左手边的筷子 wait(chopstick(i+1)%5); /请求右手边的筷子eat(); signal(chopsticki); /释放左手边的筷子signal(chopstick(i+1)%5); /释放右手边的筷子 signal(room); /退出席位释放信号量chairs 4用户名、源程序名、目标程序名和源程序4.1用户名
8、、源程序名、目标程序名用户名: 源程序名: 目标程序名:4.2源程序#include #include #include #include #define NUMBERS 5 sem_t chopsticsNUMBERS;sem_t room; sem_t mutex;int flagNUMBERS=0,0,0,0,0;int chairsNUMBERS=0,1,2,3,4;int i,j;void *Share(int threadid);int main()int error;pthread_t threadsNUMBERS;for(i=0;iNUMBERS;i+)sem_init(&ch
9、opsticsi,0,1);sem_init(&room,0,NUMBERS-1);sem_init(&mutex,0,1);for(i=0;iNUMBERS;i+)error = pthread_create(&threadsi,NULL,(void*)Share,(void *)i);if(error)printf(ERROR: thread create failed!);/exit(-1);for(i=0;iNUMBERS;i+)pthread_join(threadsi,NULL);void *Share(int threadid)int i = threadid;sem_wait(
10、&room); flagi=1;sem_wait(&chopsticsi);printf(philosopher %d get chopstics %dn,i,i);sem_wait(&chopstics(i+1)%NUMBERS);printf(philosopher %d get chopstics %dn,i,(i+1)%NUMBERS);sem_wait(&mutex);printf(n*n); printf(Dining.n); printf(philosopher: %d ,on chairs %d and eatingn,i,chairsi); for(j=0;jNUMBERS;
11、j+) if(j!=i)&flagj) printf(philosopher %d ,on chairs %d and hungryn,j,chairsj); sleep(3);sem_post(&mutex);sem_post(&chopsticsi);sem_post(&chopstics(i+1)%NUMBERS);printf(philosopher %d is full and put down chopstics %d and %d and leftn,i,i,(i+1)%NUMBERS);printf(*nn); flagi=0;sem_post(&room);5运行结果6调试记
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 操作系统 哲学家 就餐 问题 课程设计 语言 11
限制150内