模拟操作系统中哲学家就餐问题,是java编写的图形界面
2021-12-25 08:12:03 120KB java 哲学家问题
1
linux 系统C语言模拟哲学家就餐问题,可以帮助理解操作系统中线程互斥锁、互斥资源等的相关概念
2021-12-21 16:10:35 135KB Linux 线程 线程锁 操作系统
1
哲学家就餐问题哲学家就餐问题是典型的同步问题,该问题描述的是五个哲学家共用一张圆桌,分别坐在五张椅子上,在圆桌上有五个盘子和五个叉子(如下图),他们的生活方式是交替的进行思考和进餐,思考时不能用餐,用餐时不能思考。平时,一个哲学家进行思考,饥饿时便试图用餐,只有在他同时拿到他的盘子左右两边的两个叉子时才能进餐。进餐完毕后,他会放下叉子继续思考。请写出代码来解决如上的哲学家就餐问题,要求代码返回“当每个哲学家分别需要进食 n 次”时这五位哲学家具体的行为记录。 测试用例: 输入:n = 1 (1<=n<=60,n 表示每个哲学家需要进餐的次数。) 预期输出: [[4,2,1],[4,1,
2021-12-16 14:53:01 204KB fork python python实例
1
操作系统 管程实现 哲学家就餐问题 操作系统 管程实现 哲学家就餐问题 操作系统 管程实现 哲学家就餐问题 操作系统 管程实现 哲学家就餐问题 操作系统 管程实现 哲学家就餐问题
1
哲学家就餐linux下C编程源代码
2021-11-04 23:47:49 4KB C linux
1
用c语言模拟操作系统中哲学家就餐问题并实现。可在vs下运行
2021-07-04 14:38:59 6.08MB 哲学家就餐 C语言 VS 操作系统
1
操作系统死锁问题 C语言实现 有详细代码 都能实现
2021-06-22 18:18:10 7KB 死锁
1
作业6-线程同步实验-哲学家就餐问题
2021-06-16 13:13:34 363KB Linux
1
哲学家的生活就是思考和吃饭,即思考,饿了就餐,再思考,循环往复。要求是: 每一个哲学家只有在拿到位于他左右的筷子后,才能够就餐;哲学家只能先拿左边的筷子,再去拿右边的筷子,而不能同时去抓他两边的筷子,也不能从其他哲学家手中抢夺筷子;哲学家每次就餐后必须放下他手中的两把筷子后恢复思考,不能强抓住餐具不放。设计一个程序,能够显示当前各哲学家的状态和桌上餐具的使用情况,并能无死锁的推算出下一状态各哲学家的状态和桌上餐具的使用情况。即设计一个能安排哲学家正常生活的程序。 3.2 问题描述 可能出现死锁问题,因为当五个哲学家都饥饿时,都拿着一支筷子,这样就可能五个哲学家都用不上餐。 3.3 解决方案(以下解决方案均可,实现一种) 3.3.1 最多允许4个哲学家同时坐在桌子周围。 3.3.2 给所有哲学家编号,奇数号的哲学家必须首先拿左边的筷子,偶数号的哲学家则反之。 3.3.3 为了避免死锁,把哲学家分为三种状态,思考,饥饿,进食,仅当一个哲学家左右两边的筷子都可用时,才允许他拿筷子,并且一次拿到两只筷子,否则不拿。
2021-06-14 22:05:32 82KB 死锁和饥饿 哲学家就餐
1
使用Linux C 在Visual C++ 下实现的关于哲学家就餐问题
2021-06-10 15:04:07 4KB Linux 哲学家就餐
1