Управление памятью (операционные системы) - Memory management (operating systems)

В операционные системы, управление памятью это функция, отвечающая за управление компьютером первичная память.[1]:стр-105–208

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

Это отличается от управление памятью приложений, то есть как процесс управляет памятью, назначенной ему операционной системой.

Методы управления памятью

Единичное непрерывное размещение

Однократное размещение это простейший метод управления памятью. Вся память компьютера, обычно за исключением небольшой части, зарезервированной для операционной системы, доступна для одного приложения. MS-DOS это пример системы, которая распределяет память таким образом. An Встроенная система запуск одного приложения также может использовать этот метод.

Система, использующая одиночное непрерывное выделение, может многозадачность к обмен содержимое памяти для переключения между пользователями. Ранние версии МУЗЫКА операционная система использовала эту технику.

Разделенное размещение

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

Для разделения на разделы обычно требуется некоторая аппаратная поддержка, чтобы задания не мешали друг другу или операционной системе. В IBM System / 360 использовал замок и ключ техника. Другие используемые системы база и границы регистры, которые содержали пределы раздела и отмечали недопустимые обращения. В UNIVAC 1108 Реестр лимитов хранения имел отдельные базовые / привязанные наборы для инструкций и данных. Система использовала преимущества чередование памяти разместить то, что называлось я банк и d банк в отдельных модулях памяти.[2]:3–3

Перегородки могут быть либо статический, который определен в Начальная загрузка программы (IPL) или время загрузки или оператор компьютера, или же динамичный, который автоматически создается для конкретного задания. Операционная система IBM System / 360 Мультипрограммирование с фиксированным количеством задач (MFT) - пример статического разбиения, и Мультипрограммирование с переменным количеством задач (MVT) является примером динамического. MVT и его преемники используют термин область, край отличать динамические разделы от статических в других системах.[3]:73

Перегородки могут быть перемещаемый используя оборудование типизированная память, словно Корпорация Берроуз B5500, или регистры базы и границ, такие как PDP-10 или же GE-635. Переносимые перегородки могут быть уплотненный для предоставления больших фрагментов непрерывной физической памяти. Сжатие перемещает «используемые» области памяти для устранения «дыр» или неиспользуемых областей памяти, вызванных завершением процесса, с целью создания более крупных непрерывных свободных областей.[4]:94

Некоторые системы позволяют перегородкам быть поменял местами к вторичное хранилище чтобы освободить дополнительную память. Ранние версии IBM Вариант разделения времени (TSO) поменял местами пользователей на одну совместное времяпровождение раздел.[5]

Управление выгружаемой памятью

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

Обычно при управлении выгружаемой памятью каждое задание выполняется в собственном адресном пространстве. Однако есть некоторые операционные системы с единым адресным пространством которые запускают все процессы в одном адресном пространстве, например IBM i, который запускает все процессы в большом адресном пространстве, а IBM OS / VS2 SVS, который запускал все задания в едином виртуальном адресном пространстве 16 МБ.

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

Сегментированное управление памятью

Сегментированная память это единственный метод управления памятью, который не предоставляет программе пользователя «линейное и непрерывное адресное пространство».[1]:стр.165 Сегменты представляют собой области памяти, которые обычно соответствуют логической группировке информации, такой как процедура кода или массив данных. Сегментам требуется аппаратная поддержка в виде таблица сегментов который обычно содержит физический адрес сегмента в памяти, его размер и другие данные, такие как биты защиты доступа и состояние (заменено, выгружено и т. д.)

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

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

Адреса в сегментированной системе обычно состоят из идентификатора сегмента и смещения относительно базового адреса сегмента, определенного как нулевое смещение.

Intel IA-32 Архитектура (x86) позволяет процессу иметь до 16 383 сегментов размером до 4 ГБ каждый. Сегменты IA-32 являются подразделениями компьютера линейное адресное пространство, виртуальное адресное пространство, предоставляемое оборудованием подкачки.[6]

В Мультики операционная система, вероятно, самая известная система, реализующая сегментированную память. Сегменты Multics - это подразделения компьютера физическая память до 256 страниц, каждая из которых имеет размер 1K 36-битных слов, что приводит к максимальному размеру сегмента 1MiB (с 9-битными байтами, как используется в Multics). В процессе может быть до 4046 сегментов.[7]

Развертывание / развертывание

Развертывание / развертывание (RO / RI) - это метод управления памятью компьютерной операционной системы, при котором все не-общий код и данные запущенной программы выгружаются на вспомогательная память (диск или барабан) бесплатно основное хранилище для другой задачи. Программы могут быть развернуты «по окончании запроса или… в ожидании какого-то длительного события».[8] Развертывание / развертывание обычно использовалось в совместное времяпровождение системы,[9] где «время обдумывания» пользователя было относительно большим по сравнению со временем, затрачиваемым на обмен.

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

Развертывание / развертывание было дополнительной функцией Мультипрограммирование OS / 360 с переменным количеством задач (MVT)

Развертывание / развертывание позволяет временное динамическое расширение конкретного задания за пределы его первоначально указанного региона. Когда для задания требуется больше места, развертывание / развертывание пытается получить неназначенное хранилище для его использования. Если такого неназначенного хранилища нет, развертывается другое задание, т. Е. Передается во вспомогательное хранилище, чтобы его область могла использоваться первым заданием. При освобождении первым заданием это дополнительное хранилище снова становится доступным либо (1) как неназначенное хранилище, если оно было его источником, либо (2) для приема задания, которое должно быть передано обратно в основное хранилище (свернутое).[10]

Обратите внимание, что развертывание / развертывание в OS / 360 использовалось только для пакетных заданий, и повторное развертывание не происходит до тех пор, пока не завершится этап задания, заимствующий регион.

Смотрите также

Рекомендации

  1. ^ а б Мэдник, Стюарт; Донован, Джон (1974). Операционные системы. Книжная компания McGraw-Hill. ISBN  0-07-039455-5.
  2. ^ Сперри Рэнд (1970). Многопроцессорная система UNIVAC 1108: описание системы (PDF).
  3. ^ Корпорация IBM (1970). Операционная система IBM System / 360: концепции и возможности (PDF).
  4. ^ Саманта, Д. (2004). Классические структуры данных. PHI Learning Pvt. ООО ISBN  8120318749.
  5. ^ Корпорация IBM (1972 г.). Руководство по параметрам разделения времени операционной системы IBM System / 360 (PDF). п. 10.(GC28-6698-5)
  6. ^ Корпорация Intel. IA-32 Руководство разработчика программного обеспечения для архитектуры Intel Том 1: Базовая архитектура.
  7. ^ Грин, Пол. «Виртуальная память Multics - Учебник и размышления». Получено 9 мая, 2012.
  8. ^ Уолрает, Боб (28 июня 2014 г.). Программирование, Невозможный вызов. Эльзевир. п. 124. ISBN  978-0-444-87128-2. Получено 24 августа, 2018.
  9. ^ "развертывание / развертывание" Международный симпозиум по компьютерному моделированию, измерению и оценке производительности. Ассоциация вычислительной техники. 29–31 марта 1976 г. с. 137. Получено 24 августа, 2018.
  10. ^ Корпорация IBM (июнь 1970 г.). Операционная система IBM System / 360: концепции и средства. (PDF). п. 55. Получено 24 августа, 2018.