Базовые понятия операционных систем.

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

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

В каждом компьютере есть оперативная память, используемая для хранения используемых программ. В простых ОС в конкретный момент времени в памяти может находиться только одна программа. Более сложные системы позволяют одновременно хранить в памяти несколько программ.

Другой связанный с памятью вопрос – управление адресным пространством процессов. Обычно под каждый процесс отводится некоторое множество адресов, которые он может использовать. В простейшем случае, когда максимальная величина адресного пространства для процесса меньше оперативной памяти, процесс заполняет свое адресное пространство, и памяти хватает на то, чтобы содержать его целиком. Однако, что произойдет, если адресное пространство процесса окажется больше, чем ОЗУ компьютера, а процесс захочет использовать его целиком? В этом случае используется метод, называемый виртуальной памятью, при котором ОС хранит часть адресов в оперативной памяти, а часть на диске и меняет их местами при необходимости.

Файловая система – базовое понятие, поддерживаемое виртуально всеми ОС. Как было установлено раньше, основной функцией ОС является маскирование особенностей работы дисков и других устройств и предоставление пользователю понятной и удобной абстрактной модели независимых от устройств файлов. Перед тем как прочитать файл, его нужно разместить на диске и открыть, а после прочтения его нужно закрыть. Все эти функции осуществляют системные вызовы.

При создании места для хранения файлов ОС использует понятие каталога как способ объединения файлов в группы. Для создания и удаления каталога также необходимы системные вызовы. Они обеспечивают перемещение существующего файла в каталог и удаление файла из каталога. Содержимое каталога могут составлять файлы или другие каталоги. Эта модель создает структуру – файловую систему.

Иерархия процессов и файлов организованы в виде деревьев. Иерархия процессов обычно не очень глубока, в ней редко бывает больше трех уровней, тогда как файловая структура достаточно часто имеет четыре, пять и даже больше уровней в глубину.

Пример дерева каталогов изображен на рисунке:

 

Дерево каталогов.

 

Иерархия процессов обычно живет, как правило, несколько минут; иерархия каталогов может существовать годами.

Каждый файл в иерархии каталогов можно определить, задав его имя пути, называемое также полным именем файла. Путь начинается из вершины структуры каталога, называемой корневым каталогом. Такое абсолютное имя пути состоит из списка каталогов, которые нужно пройти от корневого каталога к файлу, с разделением отдельных компонентов. В MS-DOS и Windows отдельные компоненты разделяются обратной косой чертой \.

Основным понятием, связанным с операционными системами, является процесс – абстрактное понятие, описывающее работу программы.

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

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