Теория Операционных Систем
| Категория реферата: Рефераты по информатике, программированию
| Теги реферата: изложение с элементами сочинения, эффективность диплом
| Добавил(а) на сайт: Miroslav.
Предыдущая страница реферата | 1 2 3 4 5 6 7 | Следующая страница реферата
СИСТЕМА УПРАВЛЕНИя ПРОЦЕССАМИ ОБЕСПЕчИВАЕТ ПРОХОЖДЕНИЕ ПРОЦЕССА чЕРЕЗ
КОМПЬЮТЕР. В ЗАВИСИМОСТИ ОТ СОСТОяНИя ПРОЦЕССА ЕМУ ДОЛЖЕН БЫТЬ ПРЕДОСТАВИТЬ
ТОТ ИЛИ ИНОЙ РЕСУРС. НАПРИМЕР, НОВЫЙ ПРОЦЕСС НЕОБХОДИМО РАЗМЕСТИТЬ В
ОСНОВНОЙ ПАМяТИ, СЛЕДОВАТЕЛЬНО, ЕМУ НЕОБХОДИМО ВЫДЕЛИТЬ чАСТЬ АДРЕСНОГО
ПРОСТРАНСТВА. ПРОЦЕССУ В СОСТОяНИИ ГОТОВЫЙ ДОЛЖНО БЫТЬ ПРЕДОСТАВЛЕНО
ПРОЦЕССОРНОЕ ВРЕМя. ВЫПОЛНяЕМЫЙ ПРОЦЕСС МОЖЕТ ПОТРЕБОВАТЬ ОБОРУДОВАНИЕ
ВВОДА - ВЫВОДА И ДОСТУП К ФАЙЛУ.
| | |Заголово| | | | | | | |
| | |к | | | | | | | |
|Процессы | |первый | |PCB7 | |PCB8 | | | |
|в | | | | | | | | | |
|состоянии| | | | | | | | | |
|“готовый”| |последни| | | | | | | |
| | |й | | | | | | | |
| | | | | | | | | | |
| | | | | | | | | | |
|Очередь к| |первый | | | | | | | |
|магнитной| | | | | | | | | |
|ленте | |последни| | | | | | | |
| | |й | | | | | | | |
| | | | | | | | | | |
| | | | | | | | | | |
|Очередь | |первый | |PCB3 | |PCB14 | |PCB6 | |
|к | | | | | | | | | |
|диску №1 | |последни| | | | | | | |
| | |й | | | | | | | |
| | | | | | | | | | |
| | | | | | | | | | |
|Очередь к| |первый | |PCB5 | | | | | |
|терминалу| | | | | | | | | |
|№ 1 | |последни| | | | | | | |
| | |й | | | | | | | |
| | | | | | | | | | |
Распределение процессов между имеющимися ресурсами носит название планирование процессов. Одним из методом планирования процессов, ориентированных на эффективную загрузку ресурсов, является метод очередей ресурсов. Новые процессы находятся во входной очереди, часто называемой очередью работ - заданий (job queue).
Входная очередь располагается во внешней памяти, во входной очереди процессы ожидают освобождения ресурса — адресного пространства основной памяти.
Готовые к выполнению процессы располагаются в основной памяти и связаны очередью готовых процессов или ready queue. Процессы в этой очереди ожидают освобождения ресурса процессорное время.
Процесс в состоянии ожидания завершения операции ввода - вывода находится в одной из очередей к оборудованию ввода - вывода, которая носит название devices queue.
При прохождении через компьютер процесс мигрирует между различными
очередями под управлением программы, которая называется планировщик.
(scheduler) Операционная система, обеспечивающая режим
мультипрограммирования, обычно включает два планировщика — долгосрочный
(long term scheduler) и краткосрочный (short term scheduler/CPU scheduler).
Основное отличие между долгосрочным и краткосрочным планировщиками заключается в частоте запуска, например: краткосрочный планировщик может запускаться каждые 100 мс, долгосрочный — один раз за несколько минут.
Долгосрочный планировщик решает, какой из процессов, находящихся во входной очереди, должен быть переведен в очередь готовых процессов в случае освобождения ресурсов памяти.
Долгосрочный планировщик выбирает процесс из входной очереди с целью создания неоднородной мультипрограммной смеси. Это означает, что в очереди готовых процессов должны находиться в разной пропорции как процессы, ориентированные на ввод - вывод, так и процессы, ориентированные на преимущественную работу с CPU.
Краткосрочный планировщик решает, какой из процессов, находящихся в очереди готовых процессов, должен быть передан на выполнение в CPU. В некоторых операционных системах долгосрочный планировщик может отсутствовать. Например, в системах разделения времени (time sharing system), каждый новый процесс сразу же помещается в основную память.
1.3. Взаимодействие процессов. Пользовательский уровень.
СОВМЕСТНО ВЫПОЛНяЕМЫЕ ПРОЦЕССЫ МОГУТ БЫТЬ ЛИБО НЕЗАВИСИМЫМИ
(INDEPENDED PROCESSES), ЛИБО ВЗАИМОДЕЙСТВУЮЩИМИ (COOPERATING PROCESSES).
ВЗАИМОДЕЙСТВИЕ ПРОЦЕССОВ чАСТО ПОНИМАЕТСя В СМЫСЛЕ ВЗАИМНОГО ОБМЕНА ДАННЫМИ
чЕРЕЗ ОБЩИЙ БУФЕР ДАННЫХ.
Взаимодействие процессов удобно рассматривать в схеме производитель - потребитель (produces - consumer). Например, программа вывода на печать производит последовательность символов, которые потребляются драйвером принтера или компилятор производит ассемблерный текст, который затем потребляется ассемблером.
Для того, чтобы процесс - производитель и процесс - потребитель могли заполнять совместно необходимый буфер, заполняемый процессом - производителем и потребляемым процессом - потребителем.
Буфер имеет фиксированные размеры, и следовательно процессы могут
находиться в состоянии ожидания, когда:
. буфер заполнен; ожидает процесс - производитель
. буфер пуст; ожидает процесс - потребитель
Буфер может предоставляться и поддерживаться самой ОС, например с
помощью средств коммуникации процессов (IPC — Inter Process Communication), либо организовать прикладным программистом. При этом оба процесса
используют общий участок памяти, например процесс - производитель и процесс
- потребитель могут использовать следующие переменные:
Var n;
type item=...;
Var buffer:array[0..n-1] of item;
in, out:0..n-1;, где n - количество адресуемых элементов буфера, Item - имя
типа элементов буфера, in, out - указатели, характеризующие заполнение
буфера.
Буфер представлен в виде циклически связанного массива адресуемых
элементов с двумя указателями - in, out. Указатель in содержит номер
первого свободного элемента буфера, а out - первого занятого элемента
буфера.
| | | | | | | | | | | | | | | |
| | |0 |1 |2 |3 |4 |5 | | | | |n-| | |
| | | | | | | | | | | | |1 | | |
| | | | | | | | | | | | | | | |
1. Пуст. in=out. Очевидно, что буфер пуст в том случае, если выполняется это условие.
2. Буфер будет полностью заполнен, если выполняется условие
(in+1) mod n = out
Процесс - производитель должен выполнять процедуру записи в буфер
типа
Repeat
...
продуцируется очередной элемент в Next p
...
while (in+1) mod n = out do no_op; buffer (in):=next p; in:=(in+1) mod n;
until false
где Next p - локальная переменная процесса - производителя, в которой
хранится очередной продуцируемый элемент
no_op - пустой оператор
Процесс - потребитель должен выполнять процедуру чтения из буфера типа
Repeat
while in out do no_op; next p := buffer (out); out:=(out+1) mod n;
... потребляется очередной элемент из Next с
... until false
2. Планирование процессора.
КРАТКОСРОчНЫЙ ПЛАНИРОВЩИК ВЫБИРАЕТ ПРОЦЕССЫ ИЗ ОчЕРЕДИ ГОТОВЫХ
ПРОЦЕССОВ И ПЕРЕДАЕТ ИХ НА ВЫПОЛНЕНИЕ В CPU. СУЩЕСТВУЮТ РАЗЛИчНЫ АЛГОРИТМЫ
ИЛИ СТРАТЕГИИ РЕШЕНИя ЭТОЙ ЗАДАчИ, ОТЛИчАЮЩИЕСя ОТНОШЕНИЕМ К КРИТЕРИяМ
ПЛАНИРОВАНИя.
2.1. Критерии планирования процессора.
ИСПОЛЬЗУЮТСя СЛЕДУЮЩИЕ КРИТЕРИИ, ПОЗВОЛяЮЩИЕ СРАВНИВАТЬ АЛГОРИТМЫ
КРАТКОСРОчНЫХ ПЛАНИРОВЩИКОВ:
1. утилизация CPU (использование) CPU utilization. утилизация CPU теоретически может находиться пределах от 0 до 100%. В реальных системах утилизация CPU колеблется в пределах 40% для легко загруженного CPU, 90% для тяжело загруженного CPU.
2. пропускная способность CPU throughput. Пропускная способность CPU может измеряться количеством процессов, которые выполняются в единицу времени.
3. время оборота (turnaround time) для некоторых процессов важным критерием является полное время выполнения, то есть интервал от момента появления процесса во входной очереди до момента его завершения. Это время названо временем оборота и включает время ожидания во входной очереди, время ожидания в очереди готовых процессов, время ожидания в очередях к оборудованию, время выполнения в процессоре и время ввода - вывода.
4. время ожидания (waiting time). под временем ожидания понимается суммарное время нахождения процесса в очереди готовых процессов.
5. время отклика (response time) для сугубо интерактивных программ важным показателем является время отклика или время, прошедшее от момента попадания процесса во входную очередь до момента первого обращения к терминалу.
Рекомендуем скачать другие рефераты по теме: реферат личность, курсовая работа по менеджменту.
Категории:
Предыдущая страница реферата | 1 2 3 4 5 6 7 | Следующая страница реферата