Форум программистов, компьютерный форум CyberForum.ru

Задача обедающих философов - C++

Восстановить пароль Регистрация
 
xsxs2
2 / 2 / 0
Регистрация: 06.05.2012
Сообщений: 28
15.12.2012, 19:18     Задача обедающих философов #1
Здраствуйте.
Нужно написать программу, которая реализует классическую задачу обедающих философов с помощью мониторов. Не могу разобраться как применить монитор:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
monitor dp
 
{
    enum {thinking, hungry, eating} state [5];
    condition self [5];
 
void pickup (int i) {
    state [i] = hungry;
    test (i);
    if (state[i] != eating) {
    self[i].wait ();
}
}
/* pickup */
void putdown (int i) {
    state [i] = thinking;
    test ((i+4) % 5));
    test ((i-1) % 5));
    /* когда палочка свободна, проверить соседей */
}            /* putdown */
 
void test (int i) {
    if (state((i+4)%5) != eating &&
        state [i] = hungry &&
        state((i+1)%5) != eating)) {
    state[i] = eating;
    self[i].signal;
 
void init () {
for (int i = 0; i < 5; i++) {
state[i] = thinking;
}
 
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
15.12.2012, 19:18     Задача обедающих философов
Посмотрите здесь:

C++ Потоки. Event. Задача про обедающих философов.

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

Текущее время: 14:23. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru