2354 / 1772 / 212
Регистрация: 07.01.2011
Сообщений: 10,342
|
||||||
1 | ||||||
Consumer-Producer на семафорах19.05.2013, 18:56. Показов 1602. Ответов 6
Метки нет (Все метки)
Всем добрый день. Есть программа
0
|
19.05.2013, 18:56 | |
Ответы с готовыми решениями:
6
Потоки на семафорах Синхронизация потоков на семафорах Классическая задача producer\consumer Синхронизация потоков через Event-ы (задача producer/consumer) |
Ушел с форума
|
|
19.05.2013, 19:31 | 2 |
Опишите задачу подробнее. Чего именно нужно достичь ?
0
|
2354 / 1772 / 212
Регистрация: 07.01.2011
Сообщений: 10,342
|
|
19.05.2013, 20:29 [ТС] | 3 |
хорошо. Вот условие задачи - есть 2 клиента(consumer - забирают продукцию) и 3 поставщика(producer - приносят продукцию). Есть склад обьемом в 6 мест. Одновременно на складе может быть 2 человека(либо 2 костюмера, 2 продюсера или 1 продюсер и 1 костюмер). Сделать моделяцию в бесконечном цикле. Если поставщик привозит продукцию, и склад заполнен - то он должен быть в очереди и ждать когда будет свободно место. Так же как и с клиентами - если склад пуст - он ждёт когда поставщик привёзёт продукцию
0
|
Ушел с форума
|
|
19.05.2013, 21:14 | 4 |
В такой постановке задача не имеет решения.
Два consumer-а зайдут на склад и будут бесконечно ждать, пока producer-ы не привезут новый товар. А producer-ы, привезя товар, не смогут зайти на склад по условию задачи (не больше 2 человек на складе одновременно). Или ожидание товара не означает вход на склад ?
0
|
2354 / 1772 / 212
Регистрация: 07.01.2011
Сообщений: 10,342
|
|
19.05.2013, 22:24 [ТС] | 5 |
это один из возможных вариантов развития. Для этого надо просто перезапустить прогу. Вопрос не в том, а в другом. Можете скомпилировать мой прогу и посмотреть как она будет работать
Добавлено через 1 час 4 минуты ну да ))) Они становлятся в очередь, но места в складе не занимая
0
|
Ушел с форума
|
|
19.05.2013, 22:33 | 6 |
Тогда Вам нужно разделить алгоритм на две части: первая часть реализует логику борьбы за
"ключи от склада", с постановкой ожидающих потоков в очередь, а вторая занимается охраной самого входа на склад, допуская не более двоих посетителей за раз (семафор).
0
|
2354 / 1772 / 212
Регистрация: 07.01.2011
Сообщений: 10,342
|
|
19.05.2013, 22:36 [ТС] | 7 |
я не знаю как это сделать на Семафоре. Не на переменных, а на семафоре. На переменных у меня это сделано, в общих чертах
0
|
19.05.2013, 22:36 | |
19.05.2013, 22:36 | |
Помогаю со студенческими работами здесь
7
Подскажите по потокам, не могу разобраться с producer/consumer Threads Потоки синхронизация, один producer два consumer`a и очередь Nulls в Producer WildCards - producer <? extends V> то работал с программой ProShow Producer 5.0.3206? Настройка сервера MAC и запуск Podcast Producer на 10.8 Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |