Программа по параллельной работе потоков “производитель – потребитель”

Цена:
150 руб.

Состав работы

material.view.file_icon
material.view.file_icon OS4_1.EXE
material.view.file_icon OS4_1.PAS
material.view.file_icon OS4_2.EXE
material.view.file_icon OS4_2.PAS
material.view.file_icon OS4_3.EXE
material.view.file_icon OS4_3.PAS
material.view.file_icon Лабораторная 4.doc
Работа представляет собой rar архив с файлами (распаковать онлайн), которые открываются в программах:
  • Microsoft Word

Описание

ЛАБОРАТОРНАЯ РАБОТА №4
по дисциплине
«Операционные системы»

Написать программу, которая будет эмулировать параллельную работу некоторых потоков. Потоки должны работать циклически. В качестве модели использовать схему “производитель – потребитель”. Один поток (производитель) может помещать случайные (или какие-то определенные – например, только четные числа или квадраты целых чисел и т.п.) числа в буфер (массив заданного размера), для наглядности поток-производитель должен эти числа выводить на экран. Другой поток (потребитель) забирает числа из этого буфера. Для контроля также выполнять вывод на экран чисел, взятых потоком-потребителем из буфера. Вывод разными потоками выполнять в разные строки и/или разным цветом; дополнительно выводить на экран индикатор того, какой именно поток работает в настоящий момент, а также содержимое буфера и текущий процент его заполненности.
На экране параллельная работа потоков может быть представлена следующим образом:
Верхняя строка (производитель): ячейка для вывода текущего сгенерированного числа, признак активности потока (слово, символ, цвет), сообщение о переполнении буфера в случае этого события. Возможно, ещё какая-то полезная информация, например, номер заполняемой ячейки.
Нижняя (или вторая) строка (потребитель): ячейка для вывода текущего прочитанного числа, признак активности потока (слово, символ, цвет), сообщение о пустом буфере в случае этого события. Возможно, информация о номере считываемой из буфера ячейки.
В середине экрана: сам буфер, в который числа добавляются потоком-производителем и из которого считываются (удаляются или перекрашиваются, попадая при этом в его ячейку в нижней строке экрана) потоком-потребителем. Считывание чисел можно производить по принципу стека или очереди. При считывании по принципу очереди после завершения работы потребителя какое-то количество чисел из начала буфера исчезнет, следовательно, буфер будет перемещаться по экрану и в какой-то момент его потребуется переписать заново, от начала.
Отдельной строкой или в углу экрана отображать процент заполненности буфера.
Предусмотреть обработку критических ситуаций:
1) Случай, когда потребителю предоставлено управление, а буфер данных пуст – тогда активный поток должен напрямую отдать управление производителю, а сам уйти в режим ожидания. При этом вопрос с квантом времени для производителя может быть решён по-разному. Например, остаток недоработанного потребителем кванта может быть передан производителю, либо ему может быть выделен новый квант времени.
2) Случай, когда управление предоставлено производителю, а буфер полон и записывать результаты некуда – поток-производитель должен заблокироваться до появления свободного места в буфере и запустить поток-потребитель. Вопрос с квантом может решаться аналогично.

Для того чтобы было возможно пронаблюдать работу потоков в замедленном режиме, в каждом из потоков следует поставить дополнительную задержку (стандартный delay), величину которой задавать с клавиатуры при запуске программы, в качестве параметра командной строки. При запуске без параметров выводить сообщение примерного вида: “Программа запущена со стандартной задержкой, величина которой =…” и формат запуска программы для задания желаемой задержки.
Потоки при работе чередуются случайным образом; регламентировать их работу с помощью таймера (выделять каждому кванты времени, величина которых тоже случайна – в некотором диапазоне). При этом может складываться ситуация, что один и тот же поток несколько раз подряд получит управление. Таймер по окончании выделенного потоку кванта времени изменяет статус этого потока с активного на пассивный, в результате чего внутренний цикл этого потока должен завершиться.
Внутри обработчика прерываний таймера не может находиться вызовов процедур – потоков! Вызовы процедур должны происходить в бесконечном цикле в основной программе. В обработчик прерываний таймера вообще нельзя включать никакие действия, требующие длительного выполнения, например, вызовы циклических процедур, или процедур, работающих с графикой или с диском.
Для выхода из программы предусмотреть какую-то специальную клавишу или комбинацию клавиш (выбор по желанию программиста), информация о ней должна быть известна пользователю – помещена на экране. При нажатии этой клавиши происходит окончание работы потока-производителя, а поток-потребитель закончит свою работу, только когда буфер будет исчерпан, т.е. выработанная информация будет полностью использована.

Дополнительная информация

Год сдачи - 2010
Оценка - Зачет
Замечаний нет
Программа по параллельной работе потоков “производитель – потребитель”
ЛАБОРАТОРНАЯ РАБОТА №4 по дисциплине «Операционные системы» Написать программу, которая будет эмулировать параллельную работу некоторых потоков. Потоки должны работать циклически. В качестве модели использовать схему “производитель – потребитель”. Один поток (производитель) может помещать случайные (или какие-то определенные – например, только четные числа или квадраты целых чисел и т.п.) числа в буфер (массив заданного размера), для наглядности поток-производитель должен эти числа выводить на э
User hunter911 : 23 января 2011
100 руб.
Лояльность потребителей
Введение. Понятие лояльности потребителей. Понятие лояльности потребителей и её значение. Связь между уровнем удовлетворенности и лояльностью. Критерии и методы оценки лояльности потребителей. Клиентская лояльность: три модели поведения. Критерии оценки лояльности потребителей. Методика "SERVQUAL". Другие методики оценки лояльности потребителей. программы повышения лояльности. Общие сведения о программах повышения лояльности. Дисконтная программа и розыгрыши призов. Бонусные программы поощрения
User evelin : 19 июля 2015
42 руб.
Управление взаимоотношениями с потребителями.
Технологии работы с возражениями покупателей Практическая часть. 1) Краткое описание ситуации любой организации (1 стр). Вид деятельности любой. Источники информации: личный опыт работы, публикации, сайты организаций. Задания по деятельности организации: А) Какие признаки сегментирования рынка использует организация? Стратегия охвата (сегментирования) рынка? Б) Какие исследования можно провести для проверки гипотез о профилях сегментов?В) Определите возможные признаки позиционирования компании
User studypro3 : 8 февраля 2019
400 руб.
Управление взаимоотношениями с потребителями.
Технологии работы с возражениями покупателей Практическая часть. 1) Краткое описание ситуации любой организации (1 стр). Вид деятельности любой. Источники информации: личный опыт работы, публикации, сайты организаций. Задания по деятельности организации: А) Какие признаки сегментирования рынка использует организация? Стратегия охвата (сегментирования) рынка? Б) Какие исследования можно провести для проверки гипотез о профилях сегментов? ) Определите возможные признаки позиционирования компании
User studypro3 : 27 марта 2018
500 руб.
Модели поведения потребителей
В работе рассмотрены основные модели поведения потребителей, их классификация,описан процесс принятия решений, приведены особенности поведения организаций–потребителей и конечных потребителей. В практической части рассчитана сегментация рынка потребителей ООО "Лэтуаль" в г. Тула (на основе критерия Фишера) и маркетинговые исследования.
User evelin : 19 июля 2015
41 руб.
Выигрыш потребителя и производителя
1. Рынок труда в условиях совершенной конкуренции Одним из основных факторов производства является труд. Конечно, труд, как производственный ре­сурс имеет свои особенности. Главная из них состоит в том, что труд неотделим от человека и несет социальный и политический аспект. У рабочих, в отличие от машин, есть права, и на защите этих прав в современной рыночной экономике стоят профсоюзы и государство. Вместе с тем, несмотря на отмеченную выше специфику труда, при его исследовании как фактора п
User ostah : 24 сентября 2013
5 руб.
Защита прав потребителей
Экономические трудности середины 80-х годов привели к тому, что из лексикона практически исчезло слово "купить". Потребление представляло собой одну сплошную и непрервыную трудность, выразимую лишь одним роковым вопросом: "где достать". Затем пришли рыночные реформы, вслед за ними - законы, защищаюшие интересы потребителей. Казалось, достаточно добиться появления справедливых законов, предоставляющих потребителям реальную возможность защитить себя от произвола производителей и продавцов и все из
User Aronitue9 : 18 ноября 2012
5 руб.
Типы поведения потребителя
Социальное действие и поведение Единицей поведения является социальный акт, действие. "Поведение человека может быть представлено как ряд функциональных единиц, каждая из которых начинается с нарушения равновесия внутри организма и кончается восстановлением равновесия. Такая единица называется актом" (Шибутани 1969: 60). Нарушение равновесия - это, говоря иными словами, потребность. Покупка - это заключительная фаза акта, началом которого была осознанная потребность (осознание нарушения равновес
User elementpio : 15 ноября 2012
Техническая термодинамика и теплотехника УГНТУ Задача 7 Вариант 41
Для теоретического цикла ГТУ с подводом теплоты при постоянном давлении определить: — параметры (р, υ, Т) рабочего тела (воздуха) в характерных точках цикла 1, 2, 3 и 4; — подведенную и отведенную теплоту; — работу и термический КПД цикла; — теоретическую мощность ГТУ при заданном расходе воздуха G. Начальное давление р1=0,1 МПа, начальная температура t1=27 ºC, степень повышения давления в компрессоре π, температура газа перед турбиной t3. Дать схему и цикл установки в p-υ и T-
User Z24 : 19 декабря 2025
240 руб.
Техническая термодинамика и теплотехника УГНТУ Задача 7 Вариант 41
Контрольные работы по гидростатике и гидродинамике ИжГТУ 2014 Контрольная работа 2 Задача 6 Вариант 6
Определить диаметр отверстия дросселя, установленного на сливе из гидроцилиндра, при условии движения штока цилиндра под действием внешней нагрузки F со скоростью υ. Диаметры: штока dш, цилиндра D, коэффициент расхода дросселя μ, плотность жидкости ρ = 850 кг/м³, давление на сливе рс.
User Z24 : 29 декабря 2026
150 руб.
Контрольные работы по гидростатике и гидродинамике ИжГТУ 2014 Контрольная работа 2 Задача 6 Вариант 6
Расчет элементов автомобильных гидросистем МАМИ Задача 2.3 Вариант А
Вода вытекает из напорного бака, уровень жидкости в котором находится на высоте Н. Жидкость движется по трубе длиной l и диаметром d, на которой установлен кран с коэффициентом сопротивления ζкр и манометр, показывающий давление рм. Определить избыточное давление в баке р0*, при котором обеспечивается заданная величина расхода Q. При решении учесть потери напора на входе в трубу (внезапное сужение), на каждом повороте (колене) ζкол=0,5, в кране, и на трение по длине трубы λ=0,025. Режим течения
User Z24 : 18 декабря 2025
160 руб.
Расчет элементов автомобильных гидросистем МАМИ Задача 2.3 Вариант А
Оформление зала по законам флористики
Проходят времена, когда праздничный стол удивлял гостей прежде всего обилием блюд и закусок. Сегодня для создания особой атмосферы праздника недостаточно одних только явств, пусть даже незнакомых и экзотических. “Вкус” современного банкета выходит за рамки гастрономических переживаний, а выбору банкетного зала и его оформлению уделяется самое пристальное внимание. А какой же праздник без цветов? Без них не обходится ни скромный день рождения, ни грандиозная свадьба. Канули в Лету те времена, к
User Slolka : 23 августа 2013
up Наверх