Ирархия. Иерархия процесса. Состояния процесса. Операции над процессами
Скачать 351.5 Kb.
|
Иерархия процесса. Состояния процесса. Операции над процессами»ПроцессПроцесс – абстрактное понятие, описывающие работу программы. В современных ОС многозадачность реализована за счет предоставления пользовательской программе процессора на несколько миллисекунд. При условии чередования использования процессора между программами. Все ПО исполняемое на компьютере, а иногда и операционная система, организовано в виде последовательных процессов. Процессом является выполняемая программа, включая: текущие значения счетчиков команд текущие значения регистров текущие значения переменных Модель процессаКонцептуальная модель четырех независимых друг от друга последовательных процессов Четыре программы, работающие в многозадачном режиме В отдельно взятый момент времени активна только одна программа ФАКТЫЦентральный процессор переключается между процессами, следовательно, скорость вычислений процесса всегда будет разной. Процессы не должны программироваться с жестко заданным временем выполнения. Планирование процессов. Программа и процесс понятия схожие, но разные! Если программа запущенная дважды, то ею заняты два процесса Создание процессаВ универсальных системах определенные способы создания и прекращения процессов по мере необходимости. Способы создания процессов: 1. Инициализация системы 2. Выполнение работающим процессом системного запроса на создание процесса 3. Запрос пользователя на создание процесса 4. Инициализация пакетного задания Инициализация операционной системыПри загрузке ОС создается несколько процессов. Процессы, обеспечивающие взаимодействие с пользователями и выполнение заданий, являются высокоприоритетными процессами. Процессы, не связанные с конкретными пользователями, но выполняющими ряд специфических функций, являются фоновыми процессами (демонами). Пример: Получение электронной почты, web-новости, вывод на принтер Новый процесс формируется на основании системного запроса от текущего процесса. В роли текущего процесса может выступать: Процесс, запущенный пользователем; Системный процесс; Процесс, инициализированный клавиатурой или мышью; Процесс, управляющий пакетами. В UNIX существует только один системный запрос: fork (ветвление). Этот запрос создает дубликат вызываемого процесса. В Windows же вызов всего одной функции CreateProcess интерфейса Win32 управляет и созданием процесса, и запуском в нем нужной программы. Кроме CreateProcess в Win32 есть около 100 функций для управления процессами и их синхронизации Завершение процессаОбычный выход (преднамеренно); Выход по ошибке (преднамеренно); Выход по неисправимой ошибке (непреднамеренно); Уничтожение другим процессом (непреднамеренно). После окончания работы процесс генерирует системный запрос на завершение работы. В UNIX этот системный запрос – exit, а в Windows – ExitProcess. Программы, рассчитанные на работу с экраном, также поддерживают преднамеренное завершение работы Иерархия процессовВ некоторых системах родительский и дочерний процессы остаются связанными между собой определенным образом. Дочерний процесс также может, в свою очередь, создавать процессы, формируя иерархию процессов. В UNIX процесс, все его «дети» и дальнейшие потомки образуют группу процессов. Сигнал, посылаемый пользователем с клавиатуры, доставляется всем членам группы, взаимодействующим с клавиатурой в данный момент Пример иерархии процессовВ образе загрузки присутствует специальный процесс init. При запуске этот процесс считывает файл, в котором находится информация о количестве терминалов. Затем процесс разветвляется таким образом, чтобы каждому терминалу соответствовал один процесс. Процессы ждут, пока какой-нибудь пользователь не войдет в систему. Если пароль правильный, процесс входа в систему запускает оболочку для обработки команд пользователя, которые, в свою очередь, могут запускать процессы. Таким образом, все процессы в системе принадлежат к единому дереву, начинающемуся с процесса init Иерархия процессов в разных ОСВ Windows не существует понятия иерархии процессов, и все процессы равноправны. Единственное, в чем проявляется что-то вроде иерархии процессов – создание процесса, в котором родительский процесс получает специальный маркер (так называемый дескриптор), позволяющий контролировать дочерний процесс. Но маркер можно передать другому процессу, нарушая иерархию. В UNIX это невозможно Состояние процессовНесмотря на самостоятельность каждого процесса, наличие собственного счетчика команд и внутреннего состояния, процессам зачастую необходимо взаимодействовать с другими процессами. Один процесс может генерировать выходную информацию, используемую другими процессами в качестве входной информации. Пример: Выходные данные процесса cat могут служить входными данными для процесса grep. Cat chapter.txt chapter2.txt | grep tree Реализация процессовДля реализации модели процессов операционная система содержит таблицу процессов. В таблице содержится информация – о состоянии процесса, счетчик команд, указатель стека, распределение памяти, состояние открытых файлов – необходима для переключения в состояние готовности или блокировки Состояние блокировкиВозможны два вида блокировки процесса: 1. Процесс блокируется с точки зрения логики приложения (из-за отсутствия входных данных) 2. Процесс блокируется операционной системой (из-за отсутствия ресурсов) СПАСИБО ЗА ВНИМАНИЕ! |