C语言 哲学家就餐问题


哲学家就餐问题描述

问题描述问题描述从而会造成死锁问题

算法设计

算法设计

源程序

#include <stdio.h>
#include <windows.h>
#include <stdlib.h>
#include <time.h>

int i = 0;
char name[5][2] = { "0","1","2","3","4" };
FILE* fpWrite = fopen("D:\\5.txt","w");      //D盘,5.txt存放日志

DWORD WINAPI philosopher(LPVOID lpParam) {
	int id = i++;
	int num;
	HANDLE right, left;
	if (id == 0) {
		right = OpenSemaphore(SEMAPHORE_ALL_ACCESS, FALSE, name[id]);
		left = OpenSemaphore(SEMAPHORE_ALL_ACCESS, FALSE, name[(id + 4) % 5]);
	}
	else {
		left = OpenSemaphore(SEMAPHORE_ALL_ACCESS, FALSE, name[id]);
		right = OpenSemaphore(SEMAPHORE_ALL_ACCESS, FALSE, name[(id + 4) % 5]);
	}
	while (1) {
		srand((unsigned int)time(0));
		num = rand()%400+100;
		fprintf(fpWrite,"哲学家%d开始思考,将思考%dms\n", id, num);
		Sleep(num);
		num = rand()%400+100;
		fprintf(fpWrite,"哲学家%d开始休息,将休息%dms\n", id, num);
		Sleep(num);
		WaitForSingleObject(left, INFINITE);
		fprintf(fpWrite,"哲学家%d取了左手边的筷子\t%d\n", id, id);
		WaitForSingleObject(right, INFINITE);
		fprintf(fpWrite,"哲学家%d取了右手边的筷子\t%d\n", id, (id + 4) % 5);
		num = rand() % 400 + 100-2;
		fprintf(fpWrite,"哲学家%d开始吃饭,将吃饭%dms\n", id, num);
		Sleep(num);
		ReleaseSemaphore(left, 1, NULL);
		fprintf(fpWrite,"哲学家%d放下左手边的筷子\t%d\n", id, id);
		ReleaseSemaphore(right, 1, NULL);
		fprintf(fpWrite,"哲学家%d放下右手边的筷子\t%d\n", id, (id + 4) % 5);
	}
}
int main(void) {
	HANDLE S[5];
	HANDLE hThread[5];
	for (int i = 0; i < 5; i++) {
		S[i] = CreateSemaphore(NULL, 1, 1, name[i]);
	}

	for (int i = 0; i < 5; i++) {
		hThread[i] = CreateThread(NULL, 0, philosopher, NULL, 0, NULL);
	}
	WaitForMultipleObjects(5, hThread, TRUE, 10000); 	
	for (int i = 0; i < 5; i++) {
		CloseHandle(S[i]);
	}
	fclose(fpWrite);
}

测试

测试测试


总结

本文简单介绍了哲学家就餐问题,并进行了简单实现。
有任何问题都可以在评论区和我交流~~

  • 2
    点赞
  • 35
    收藏
    觉得还不错? 一键收藏
  • 11
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值