Я пытаюсь решить проблему обедающих философов и каждый раз печатаю, что едят только двое. Каждый созданный мной поток был философом, и каждый раздел был вилкой, и в соответствии с алгоритмом, каждый раз, когда мы отправляем философа, мы пытаемся получить его вилки (в первую очередь это fork1 и fork2), а вилки являются критическими секциями. Есть идеи, как это исправить? Вот мой код:
#include <windows.h>
#include <stdio.h>
#include <tchar.h>
#include <tchar.h>
#include <iostream>
#include <chrono>//To check runtime(it was also asked but I know how to do this)
#include <thread>
using namespace std;
CRITICAL_SECTION ghCARITICALSection1;
CRITICAL_SECTION ghCARITICALSection2;
//Same for the rest
DWORD WINAPI func(int* phiphilosopher)
{
if (1 == *phiphilosopher)
{
if (TryEnterCriticalSection(&ghCARITICALSection1)) {
if (TryEnterCriticalSection(&ghCARITICALSection2)) {
cout << "1 is eating..."<< endl;
for (int i = 0; i < 1000000; i++)
{
i = i;
}
LeaveCriticalSection(&ghCARITICALSection2);
}
LeaveCriticalSection(&ghCARITICALSection1);
}
}
//Same for the rest but with all the numbers increased and on the 5th we check 5 and 1
И это главное:
int main()
{
int philosopher1 = 1;
int* philosopher1ptr = &philosopher1;
//Same for the rest
InitializeCriticalSection(&ghCARITICALSection1);
InitializeCriticalSection(&ghCARITICALSection2);
//Same for the rest
HANDLE WINAPI th1 = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)func, philosopher1ptr, 0, NULL);
//Same for the rest
WaitForSingleObject(th1, INFINITE);
//Same for the rest
}