Сетевые операционные системы

       

Процессы и нити


В разных ОС процессы реализуются по-разному. Эти различия заключаются в том, какими структурами данных представлены процессы, как они именуются, какими способами защищены друг от друга и какие отношения существуют между ними. Процессы Windows NT имеют следующие характерные свойства:

  • Процессы Windows NT реализованы в форме объектов, и доступ к ним осуществляется посредством службы объектов.

  • Процесс Windows NT имеет многонитевую организацию.

  • Как объекты-процессы, так и объекты-нити имеют встроенные средства синхронизации.

  • Менеджер процессов Windows NT не поддерживает между процессами отношений типа "родитель-потомок".

    В любой системе понятие "процесс" включает следующее:

  • исполняемый код,

  • собственное адресное пространство, которое представляет собой совокупность виртуальных адресов, которые может использовать процесс,

  • ресурсы системы, такие как файлы, семафоры и т.п., которые назначены процессу операционной системой.

  • хотя бы одну выполняемую нить.

    Адресное пространство каждого процесса защищено от вмешательства в него любого другого процесса. Это обеспечивается механизмами виртуальной памяти. Операционная система, конечно, тоже защищена от прикладных процессов. Чтобы выполнить какую-либо процедуру ОС или прочитать что-либо из ее области памяти, нить должна выполняться в режиме ядра. Пользовательские процессы получают доступ к функциям ядра посредством системных вызовов. В пользовательском режиме выполняются не только прикладные программы, но и защищенные подсистемы Windows NT.

    В Windows NT процесс - это просто объект, создаваемый и уничтожаемый менеджером объектов. Объект-процесс, как и другие объекты, содержит заголовок, который создает и инициализирует менеджер объектов. Менеджер процессов определяет атрибуты, хранимые в теле объекта-процесса, а также обеспечивает системный сервис, который восстанавливает и изменяет эти атрибуты.

    В число атрибутов тела объекта-процесса входят:

  • Идентификатор процесса - уникальное значение, которое идентифицирует процесс в рамках операционной системы.


  • Токен доступа - исполняемый объект, содержащий информацию о безопасности.



  • Базовый приоритет - основа для исполнительного приоритета нитей процесса.

  • Процессорная совместимость - набор процессоров, на которых могут выполняться нити процесса.

  • Предельные значения квот - максимальное количество страничной и нестраничной системной памяти, дискового пространства, предназначенного для выгрузки страниц, процессорного времени - которые могут быть использованы процессами пользователя.

  • Время исполнения - общее количество времени, в течение которого выполняются все нити процесса.

    Напомним, что нить является выполняемой единицей, которая располагается в адресном пространстве процесса и использует ресурсы, выделенные процессу. Подобно процессу нить в Windows NT реализована в форме объекта и управляется менеджером объектов.

    Объект-нить имеет следующие атрибуты тела:

  • Идентификатор клиента - уникальное значение, которое идентифицирует нить при ее обращении к серверу.

  • Контекст нити - информация, которая необходима ОС для того, чтобы продолжить выполнение прерванной нити. Контекст нити содержит текущее состояние регистров, стеков и индивидуальной области памяти, которая используется подсистемами и библиотеками.

  • Динамический приоритет - значение приоритета нити в данный момент.

  • Базовый приоритет - нижний предел динамического приоритета нити.

  • Процессорная совместимость нитей - перечень типов процессоров, на которых может выполняться нить.

  • Время выполнения нити - суммарное время выполнения нити в пользовательском режиме и в режиме ядра, накопленное за период существования нити.

  • Состояние предупреждения - флаг, который показывает, что нить должна выполнять вызов асинхронной процедуры.

  • Счетчик приостановок - текущее количество приостановок выполнения нити.

    Кроме перечисленных, имеются и некоторые другие атрибуты.

    Как видно из перечня, многие атрибуты объекта-нити аналогичны атрибутам объекта-процесса. Весьма сходны и сервисные функции, которые могут быть выполнены над объектами-процессами и объектами-нитями: создание, открытие, завершение, приостановка, запрос и установка информации, запрос и установка контекста и другие функции.


    Содержание раздела