Организация памяти в ЭВМ
Стратегии размещения информации в памяти. Алгоритмы распределения адресного пространства оперативной памяти. Описание характеристик модели и ее поведения, классов и элементов. Выгрузка и загрузка блоков из вторичной памяти. Страничная организация памяти.
Рубрика | Программирование, компьютеры и кибернетика |
Вид | курсовая работа |
Язык | русский |
Дата добавления | 31.05.2013 |
Размер файла | 708,6 K |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
Размещено на http://www.allbest.ru/
Содержание
Введение
1. Общесистемная часть
1.1 Организация памяти в ЭВМ.
1.2 Организация доступа к ресурсу ОП.
1.3 Физическая память.
1.4 Стратегии размещения информации в памяти.
1.5 Страничная организация памяти
1.6 Алгоритмы распределения адресного пространства ОП.
2. Специальная часть.
2.1 Постановка целей и задач.
2.2 Использование методов имитационного моделирования для решения поставленной задачи
2.3 Описание характеристик модели и ее поведения
2.3.1 Описание адресного пространства ОП.
2.3.2 Описание страницы.
2.3.3 Описание модели системы.
2.4 Описание классов и элементов
2.4.1 Описание класса страницы
2.4.2 Описание адресного пространства ОП
2.4.3 Описание модели системы
2.5 Внешний вид разработанного приложения и описание работы с программой.
Заключение
Список источников
Приложение 1. Листинг исходного кода программы.
Введение
Одним из наиболее сложных аспектов разработки операционной системы является управление памятью. Хотя стоимость памяти постоянно снижается и в результате растет размер основной памяти на современных машинах, достигая гигабайтного диапазона, ее всегда недостаточно для хранения всех программ и структур данных, необходимых активным процессам и операционной системе в целом. Соответственно, одной из центральных задач операционной системы является управление памятью, включая выгрузку и загрузку блоков из вторичной памяти. Однако операции ввода - вывода довольно медленные, и их скорость с каждым годом отстает от скорости работы процессора. Для эффективной работы процессора операционная система должна четко рассчитывать процессы подкачки для минимизации влияния операций ввода - вывода на производительность. Моделированием одной из ее функций мы и займемся в данной курсовой работе.
1. Общесистемная часть
1.1 Организация памяти в ЭВМ
Компактные микроэлектронные запоминающие устройства, так называемая «память», широко применяются в современной аппаратуре самого различного назначения. Но, тем не менее, разговор о классификации памяти, её видах следует начать с определения места и роли, отведённой памяти в ЭВМ. Память является одной из самых главных функциональных частей машины, предназначенной для записи, хранения и выдачи команд и обрабатываемых данных. Следует сказать, что команды и данные поступают в ЭВМ через устройство ввода, на выходе которого они получают форму кодовых комбинаций 1 и 0. Основная память, как правило, состоит из запоминающих устройств двух видов - оперативного (ОЗУ) и постоянного (ПЗУ).
ОЗУ предназначено для хранения переменной информации; оно допускает изменение своего содержимого в ходе выполнения вычислительного процесса. Таким образом, процессор берёт из ОЗУ код команды и, после обработки каких-либо данных, результат обратно помещается в ОЗУ. Причем возможно размещение в ОЗУ новых данных на месте прежних, которые при этом перестают существовать. В ячейках происходит стирание старой информации и запись туда новой. Из этого видно, что ОЗУ является очень гибкой структурой и обладает возможностью перезаписывать информацию в свои ячейки неограниченное количество раз по ходу выполнения программы.
ПЗУ содержит такой вид информации, которая не должна изменяться в ходе выполнения процессором программы. Такую информацию составляют стандартные подпрограммы, табличные данные, коды физических констант и постоянных коэффициентов. Эта информация заносится в ПЗУ предварительно, и блокируется путем пережигания легкоплавких металлических перемычек в структуре ПЗУ. В ходе работы процессора эта информация может только считываться. Таким образом, ПЗУ работает только в режимах хранения и считывания.
1.2 Организация доступа к ресурсу ОП
Ресурсом называется средство вычислительной системы, которое может быть выделено процессу на определенный интервал времени. Все ресурсы вычислительной системы (ВС) можно разделить на физические и виртуальные. Физические ресурсы - реально существующие ресурсы, обладающие всеми физическими свойствами при распределении между процессами. Виртуальный ресурс является некоторой моделью физического и не существует реально в том виде, в котором предоставляется процессу. Примерами виртуальных ресурсов могут служить виртуальная память, виртуальные регистры, виртуальные CD-ROM приводы и пр.
Размер оперативной памяти (как правило, значительно уступающий размерам виртуальной памяти, выделяемой процессам в системе) может накладывать существенные ограничения на количество одновременно находящихся в системе процессов и скорость их исполнения, что связано с невозможностью предоставления каждому процессу участка соответствующего размера в ОП и, неизбежным в связи с этим, перемещения процессов с ВЗУ в ОП и наоборот. Поэтому схема функционирования оперативной и виртуальной памяти во многом определяет работу операционной системы в целом и ее отдельных приложений в частности.
Основная (оперативная) память всегда была и остается до сих пор наиболее критическим ресурсом компьютеров. Если учесть, что большинство современных компьютеров обеспечивает 32-разрядную адресацию в пользовательских программах, и все большую силу набирает новое поколение 64-разрядных компьютеров, то становится понятным, что практически безнадежно рассчитывать, что когда-нибудь удастся оснастить компьютеры основной памятью такого объема, чтобы ее хватило для выполнения произвольной пользовательской программы, не говоря уже об обеспечении мультипрограммного режима, когда в основной памяти, вообще говоря, могут одновременно содержаться несколько пользовательских программ.
Поэтому всегда первичной функцией всех операционных систем (более точно, операционных систем, обеспечивающих режим мультипрограммирования) было обеспечение разделения основной памяти между конкурирующими пользовательскими процессами. Мы не будем здесь слишком сильно вдаваться в историю этого вопроса. Заметим лишь, что применявшаяся техника распространяется от статического распределения памяти (каждый процесс пользователя должен полностью поместиться в основной памяти, и система принимает к обслуживанию дополнительные пользовательские процессы до тех пор, пока все они одновременно помещаются в основной памяти), с промежуточным решением в виде "простого своппинга" (система по-прежнему располагает каждый процесс в основной памяти целиком, но иногда на основании некоторого критерия целиком сбрасывает образ некоторого процесса из основной памяти во внешнюю память и заменяет его в основной памяти образом некоторого другого процесса), до смешанных стратегий, основанных на использовании "страничной подкачки по требованию" и развитых механизмов своппинга.
1.3 Физическая память
Организация и управление основной или первичной или физической (реальной) памятью вычислительной машины -- один из самых важных факторов, определяющих построение операционных систем. Для непосредственного выполнения программ или обращения к данным необходимо, чтобы они размещались в основной памяти. Вторичная, или внешняя память -- это, как правило, накопители на магнитных дисках, магнитных барабанах и магнитных лентах -- их емкость много больше и позволяет хранить множество программ и данных, которые должны быть наготове для обработки.
Организация памяти -- это способ представления и использования основной памяти. Распространенными способами организации памяти для системы с физической памятью являются:
· однопрограммные (одно абонентские) системы;
· мультипрограммные системы с фиксированными разделами, с трансляцией и загрузкой модулей в абсолютных адресах;
· мультипрограммные системы с фиксированными разделами, с трансляцией и загрузкой перемещаемых модулей;
· мультипрограммные системы с переменными разделами;
· системы со свопингом.
Цель стратегий управления памятью заключается в том, чтобы обеспечить наиболее эффективное использование такого дорогостоящего ресурса, каким является основная память, и при этом достигнуть наивысших возможных скоростных характеристик машины. Существует три вида стратегий управления памятью:
· стратегии выборки;
· стратегии размещения;
· стратегии замещения.
Стратегии выборки ставят своей целью определить, когда следует выбирать очередной блок программы или данных для переписи в основную память. Стратегии выборки по запросу (по требованию) предусматривают загрузку в память блоков программ и данных только в тот момент, когда они запрашиваются. В стратегиях выборки с упреждением система пытается предупредить запросы программы пользователя и загружает соответствующие блоки программ и данных в основную память еще до того, как они реально потребуются; таким образом, эти блоки уже будут находиться в основной памяти, так что обращающаяся к ним программа сможет продолжать свое выполнение без задержки.
1.4 Стратегии размещения информации в памяти
Стратегии размещения информации в памяти предназначены для того, чтобы определить, в какое место основной памяти следует помещать поступающие программы и данные при распределении памяти неперемещаемыми разделами. Наиболее часто применяются следующие стратегии:
размещение с выбором первого подходящего (стратегия “первый подходящий”):
размещение с выбором наиболее подходящего (стратегия “самый подходящий”);
алгоритм с выбором наименее подходящего (стратегия “самый неподходящий”).
Стратегия “первый подходящий” состоит в выполнении следующих шагов:
упорядочить таблицу свободных областей в порядке возрастания адресов;
поместить информацию в первый встретившийся участок основной памяти размером не менее требуемого.
Стратегия “самый подходящий” реализует следующую последовательность действий:
упорядочить таблицу свободных областей в порядке возрастания размеров свободных областей:
поместить информацию в первый встретившийся участок свободной памяти размером не менее требуемого.
Стратегия “самый неподходящий” выполняет следующие действия:
упорядочить таблицу свободных областей в порядке убывания размеров областей;
поместить информацию в первый встретившийся участок свободной памяти размером не менее требуемого.
Строгих доказательств преимуществ той или иной стратегии перед остальными не существует, так что их применение в операционных системах основано на интуитивных аргументах разработчиков ОС.
1.5 Страничная организация памяти
При построении виртуальной оперативной памяти применяют несколько способов адресации в пределах как виртуального, так и физического адресного пространства. Каждый вариант адресации основан на конкретной схеме структуризации адресного пространства.
Различаются два класса схем структуризации:
· схемы страничной структуризации;
· схемы сегментной структуризации.
Страничная организация памяти состоит в разбиении программы на части фиксированной длины, называемые страницами; длина страницы обычно определяется особенностями аппаратных средств и другими системными факторами. Фирма IBM, например, использует в своих системах страничной организации памяти страницы двух размеров: в 2К и в 4К. Из нашего обсуждения механизма защиты памяти в операционной системе OS/MFT фирмы IBM вы, вероятно, помните, что память в этой системе распределяется между программами порциями емкостью в два К; отсюда - 2К - байтовые страницы. Программирующие на языке ассемблера конечна не могут не осознавать значения числа 4К -- оно определяет максимальный адрес, сопоставляемый одному регистру базы. При столь коротких страницах и хорошо согласованном спектре длин сегментов с используемой системой распределения памяти вероятность возникновения неиспользованных областей памяти значительно снижается.
За исключением того, что страницы имеют фиксированный размер, реализация системы страничной организации памяти почти идентична реализации системы сегментации. Программы загружаются в память разрозненными страницами (рис. 1). Адрес разбивается на две части (рис. 2) с номером страницы, занимающим старшие разряды и смещением - в младших разрядах; в процессе выполнения программы адреса динамически преобразуются с помощью таблицы страниц программы (рис. 3). То, что ранее называлось регистром размещения таблицы сегментов, теперь будет называться регистром размещения таблицы страниц.
Рис. 1. Загрузка программы в системе
Рис. 2. Адресация в системе со страничной организацией памяти
Рис. 3. Динамическое преобразование адресов в системе со страничной -организацией памяти
В системе страничной организации памяти несколько легче прослеживается распределение памяти; память просто делится на ряд страниц фиксированной длины (рис. 4), при этом в таблице описания страниц (рис. 5) состояние каждой страницы (свободна или занята) задается одноразрядным флажком.
Рис. 4. Память, разделенная на страницы.
Рис. 5. Таблица содержания страниц
При необходимости определения адреса свободного фрагмента памяти программе главного планировщика или программе-инициатору (или каким-либо их аналогам) достаточно найти в таблице содержимого таблиц элемент с нулевым значением признака состояния, присвоить соответствующую страницу загружаемой программе и изменить значение признака состояния на единицу. Следует заметить, что между этой таблицей содержимого страниц и таблицей страниц программы, описанной выше, имеется существенная разница. Таблица содержимого страниц используется операционной системой при распределении памяти, тогда как таблицей страниц программ обеспечивается динамическое преобразование адресов выполняемых программ, которые уже находятся в памяти.
Как мы уже видели, некоторая потеря памяти неизбежна при любой схеме ее распределения; страничная организация памяти даже при фиксированных размерах модулей сталкивается с той же проблемой, хотя и в несколько ином плане. Проблема страничной организации памяти, если сформулировать ее как можно проще, состоит в том, что любой фиксированный размер страницы неизбежно оказывается не подходящим. Эта формулировка, вероятно, требует небольшого пояснения. Программисты не пишут своих программ частями фиксированной длины; почти; в любой программе найдется, по крайней мере, одна страница, используемая не полностью. Даже если в среднем это составляет 1К на программу, то в системе мультипрограммирования, работающей с 10 программами, суммарная потеря памяти составит целых 10К[1]!
1.6 Алгоритмы распределения адресного пространства ОП
Алгоритм распределения адресного пространства оперативной памяти отличен от алгоритма распределения адресного пространства виртуальной памяти.
Нерационально, например, использовать распределение страниц по правилу «без перераспределения», поскольку цена потерь из-за наличия «псевдосвободных» страниц была бы слишком высока. Переполнение адресного пространства наступало бы слишком часто. При вытеснении «псевдосвободных» страниц пришлось бы не только корректировать адреса занятых участков, но и переписывать информацию из них. При этом требовалось бы производить еще и коррекцию содержимого этих участков, если информация в них носила бы адресный характер.
Вместе с тем сравнительно небольшой объем адресного пространства оперативной памяти и структурирование его страницами фиксированного размера могут существенно облегчить построение алгоритма. Разовый запрос от каждого из процессов на выделение памяти согласно рассматриваемой схеме функционирования виртуальной памяти может быть только на одну страницу. В ответ на запрос указывается номер некой «свободной» страницы из набора номеров свободных страниц в текущий момент времени. Причем не накладываются никакие требования на «соседей» выделяемой страницы. Это могут быть либо свободные, либо распределенные страницы.
Для выполнения распределения ведут учет свободных и распределенных страниц. Наиболее простой метод учета основан на использовании двоичного вектора. Число двоичных разрядов вектора равно числу страниц адресного пространства оперативной памяти. Двоичные разряды нумеруются в том же порядке, что и страницы. Тогда значение двоичного разряда с номером i будет однозначно определять текущее состояние страницы с номером i. Страница свободна, если значение равно 0, и распределена, если значение равно 1. Для выделения свободной страницы достаточно найти в двоичном векторе нулевой разряд, номер которого и будет равен номеру распределяемой страницы. После распределения нулевой разряд устанавливается в 1.
При данном способе структуризации возможно и используется перераспределение страниц. Если в некоторый момент обнаруживается, что свободных страниц нет, то ищется «кандидат» на перераспределение из числа уже распределенных страниц. Информацию, соответствующую странице-кандидату, переносят на уровень внешней памяти (в архивную среду). Затем освобожденную таким «насильственным» образом страницу закрепляют за процессом, выдавшим требование на выделение страницы. Выбор страницы-кандидата, а также перенос информации в архив осуществляются механизмами, реализующими решение задач замещения и перемещения.
2. Специальная часть
2.1 Постановка целей и задач
Задание: Разработка модели задачи размещения информации в адресном пространстве ОП при структуризации фиксированными страницами.
Постановка задачи:
Необходимо смоделировать задачу размещения информации в адресном пространстве ОП при структуризации фиксированными страницами. Для этого необходимо создать модель, которая бы занималась структурированием адресного пространства, в зависимости от размера самого адресного пространства и размера страниц. Модель должна позволять размещать страницы в адресном пространстве ОП (в соответствии с алгоритмом) и освобождать, а также замещать при переполнении. Перечисленные задачи являются отправной точкой для реализации модели и определяют взаимодействие всех ее элементов.
2.2 Использование методов имитационного моделирования для решения поставленной задачи
Замещение одного объекта другим с целью получения информации о важнейших свойствах объекта-оригинала с помощью объекта-модели называется моделированием.
Широкое применение имитационного моделирования в ходе проектирования и эксплуатации сложных систем делает актуальным задачу создания методик построения, испытания и верификации имитационного моделирования для сложных систем.
Основным методом исследования сложных систем является метод математического моделирования. Под математическим моделированием понимают описание поведения физических систем при помощи математических уравнений или соотношений.
Отличительная особенность моделирования как метода исследования заключается в возможности изучения, прогнозирования и оптимизации таких процессов и объектов, с которыми очень затруднителен или экономически невыгоден физический (натурный) эксперимент. Во многих случаях натурный эксперимент опасен и может быть выполнен лишь один раз (изменение состояния экосистем, управление климатом), он требует много времени (селекционные исследования) или попросту невозможен (воспроизводство гео- и астрофизических процессов).
Использование имитационного моделирования рекомендуется в следующих случаях:
· Нет законченной постановки задачи и идет процесс познания объекта моделирования;
· Аналитические методы имеются, но позволяют оценить очень грубо свойства сложной системы;
· Желательно получить характеристики всех входных координат, компонент, составляющих сложную систему;
· Необходимо произвести моделирование в ускоренном или замедленном масштабе времени.
Обобщенно, моделирование можно определить как метод опосредованного познания, при котором изучаемый объект-оригинал находится в некотором соответствии с другим объектом-моделью, причем модель способна в том или ином отношении замещать оригинал на некоторых стадиях исследования.
Процесс моделирования предполагает наличие объекта исследования; исследователя, перед которым поставлена конкретная задача; модели, создаваемой для получения информации об объекте и необходимой для решения поставленной задачи.
Для моделирования объектов и процессов используется, как правило, имитационное моделирование. При проведении имитационных экспериментов моделируются поведение различных частей комплексов (как динамических объектов) и их взаимодействия с учетом внешних возмущающих факторов и параметрических возмущений.
Каждая модель представляет собой комбинацию таких составляющих, как
· Компонент - составные части, которые при объединении образуют систему.
· Переменные - описывают входы и выходы компоненты. В тех случаях, когда переменные изменяют состояние компоненты, их называют переменные состояния.
· Параметры - значения характеризующие состояние компоненты.
· Функциональные зависимости - определяют поведение переменных в пределах компоненты.
· Ограничения - представляют собой устанавливаемые пределы изменения переменных.
· Целевые функции - характеризируют динамические свойства или иные свойства системы.
Моделирование с помощью ЭВМ, т.е. имитационное моделирование, является в настоящее время одним из наиболее эффективных средств исследования сложных систем (СС).
2.3 Описание характеристик модели и ее поведения
Так как разрабатываемая модель не рассчитывает на полное описание функционирования работы управления адресным пространством ОП, то ее параметры и функции ограничены демонстрацией только некоторых возможностей.
Для реализации всего механизма размещения в адресном пространстве ОП при структуризации фиксированными страницами создаются: модель адресного пространства ОП, модель страницы, модель системы.
2.3.1 Описание адресного пространства ОП
Параметры:
· размер адресного пространства
· размер страницы
Функции:
· графическое отображение адресного пространства ОП
· изменение размера адресного пространства
· изменение размера страниц
2.3.2 Описание страницы
Параметры:
· признак занятости страницы
· размер страницы
· адрес страницы
· имя (идентификатор) страницы
Функции:
· графическое отображение страницы
· вывод информации о странице
2.3.3 Описание модели системы
Параметры:
· двоичный вектор (информация о занятых страницах)
· список адресов размещенных страниц
· поля для ввода данных
· кнопки для регистрации ввода
Функции:
· установление значений параметров, введенных пользователем
· поиск свободных страниц, имитация занятости страницы
· очистка адресного пространства
· замещение страниц при переполнении адресного пространства
· освобождение занятых страниц
2.4 Описание классов и элементов
Программная реализация была выполнена в среде Visual Studio на языке высокого уровня C#.
2.4.1 Описание класса страницы
Страница реализуется при помощи создания пользовательского типа
public class Page , который представляет собой класс страницы:
· string name - имя (идентификатор) страницы
· int size - размер страницы
· int adress - адрес страницы
· bool busy - логическая переменная, определяющая занятость страницы
· Rectangle rect - графические размеры страницы
· public Page - конструктор для инициализации экземпляра класса страницы
· public int Size - открытое свойство для изменения размера страницы
· public int Adress - открытое свойство для изменения адреса страницы
· public Rectangle Rect - открытое свойство для изменения графических размеров страницы
· public string Name - открытое свойство для изменения имени страницы
· public bool Busy - открытое свойство для изменения занятости страницы
· public void Draw - функция реализующая графическое отображение страницы
Вид класса страницы в работе и описание составных частей:
Рис.1 «вид страницы в приложении»
2.4.2 Описание адресного пространства ОП
Адресное пространство ОП реализуется при помощи стандартной компоненты Visual Studio C# - PictureBox, которая задает область графического отображения адресного пространства на форме приложения. Помимо нее используются параметры и функции:
· int APOPsize - размер адресного пространства
· private void Form1_Paint(object sender, PaintEventArgs e) - функция обработчик события графического отображения АП
Вид адресного пространства ОП в работе и описание составных частей:
Рис.2 «вид компоненты адресного пространства»
2.4.3 Описание модели системы
Для реализации взаимодействия в модели используются следующие параметры и функции:
· int count - переменная для задания идентификатора странице
· int size - переменная для задания размера страниц
· Page[] binaryvector - структура данных хранящая информацию о занятых и свободных страницах
· private void button1_Click(object sender, EventArgs e) - функция обработчик события размещения страницы в адресном пространстве
· private void button2_Click(object sender, EventArgs e) - функция обработчик события освобождения страницы
· private void pictureBox1_Paint(object sender, PaintEventArgs e) - функция обработчик события графического отображения страниц в АП
· private void button3_Click(object sender, EventArgs e) - функция обработчик события освобождения всех занятых страниц
· private void button4_Click(object sender, EventArgs e) - функция обработчик события задания размера страниц
· private void button5_Click(object sender, EventArgs e) - функция обработчик события задания размера АП
Вид системы в работе и описание составных частей
Рис.3 «вид системы при работе»
2.5 Внешний вид разработанного приложения и описание работы с программой.
При запуске программы мы видим следующее окно:
Рис.4 «вид приложения №1, вид при запуске»
В названии приложения мы видим название программы. Слева располагается компонента, отображающая адресное пространство ОП. Справа находятся элементы управления. Пользователю предлагается ввести размер адресного пространства ОП и нажать кнопку «Задать».
При нажатии на кнопку «Задать» запоминается размер адресного пространства ОП, поле «Размер АП ОП» и кнопка «Задать» деактивируются, а поле «Размер страницы» и кнопка «Задать» станут активны.
Рис.5 «вид приложения №2, активация поля «Размер страницы» и кнопки «Задать»»
После ввода необходимого размера страницы при нажатии кнопки ««Задать»» запоминается размер страницы. После чего поле «Размер страницы» и кнопка «Задать» деактивируются и включается кнопка «Добавить»
Рис.6 «вид приложения №3, кнопки «Добавить»»
При нажатии на кнопку «Добавить» происходит размещение в адресном пространстве страницы информации. Активируется список «Адреса страниц» и кнопка «Удалить»
Рис.7 «вид приложения №4, размещение в адресном пространстве»
После размещения появляется возможность освободить занятые страницы
Рис.8 «вид приложения №5, освобождение страниц»
После чего при добавлении используются выше освобожденные страницы
Рис.9 «вид приложения №6, повторное заполнение»
При переполнении адресного пространства ОП происходит замещение любой случайно выбранной страницы
Рис.10 «вид приложения №7, переполнение»
Кнопка «Очистить» позволяет освободить все страницы адресного пространства ОП.
Рис.11 «вид приложения №8, очистка»
Заключение
В данном курсовой работе была поставлена задача создания модели размещения информации в адресном пространстве ОП при структуризации фиксированными страницами.
В результате работы была создана модель, позволяющая пользователю размещать, освобождать и замещать страницы в адресном пространстве ОП. В процессе функционирования модели пользователь имеет возможность регулировать параметры: влиять на размер адресного пространства ОП, изменять размер страницы. Пользователь может в реальном времени просматривать графическое отображение занятости ОП. Эта модель демонстрирует данный подхода к структуризации адресного пространства оперативной памяти и является адекватной системе управления, так как есть возможность контролировать ход моделирования и наблюдать за происходящими процессами с помощью таблиц и графического изображения.
Список источников
1. Г. Дейтел «Введение в операционные системы», М.: «Мир» ,1987 г.
2. Г.Н. Соловь?в, В.Д. Никитин «Операционные системы ЭВМ», М.: «Выс-шая школа» ,1989 г.
3. И.В. Максимей «Имитационное моделирование на ЭВМ», М.: «Радио и связь», 1988 г.
4. В. Столингс «Операционные Системы», М.: «Питер», 2002 г.
5. Э. Троелсен «Язык программирования С# 2005 и платформа .NET 2.0» , М.: «Вильямс», 2007 г.
Приложение 1. Листинг исходного кода программы
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Drawing.Drawing2D;
namespace Курсовая
{
public partial class Курсовая : Form
{
Page[] binaryvector; //структура данных хранящая иформацию о занятых и свободных страницах
int count;//вспомогательная переменная для задания идентификатора страницам
int APOPsize;//размер АП ОП
int size;//размер страниц
public Курсовая()
{
InitializeComponent();
size = 16;
binaryvector = new Page[APOPsize / size];
count = 0;
APOPsize = 256;
}
public class Page//класс страницы
{
string name;//идентификатор
int size;//размер
int adress;//адрес
bool busy;//занятость страницы
Rectangle rect;
public Page(int adress, int size, Rectangle rect)//конструктор
{
this.adress = adress;
this.size = size;
this.rect = rect;
}
public int Size
{
get { return size; }
set { size = value; }
}
public int Adress
{
get { return adress; }
set { adress = value; }
}
public Rectangle Rect
{
get { return rect; }
set { rect = value; }
}
public string Name
{
get { return name; }
set { name = value; }
}
public bool Busy
{
get { return busy; }
set { busy = value; }
}
public void Draw(Graphics g)//отрисовка на форме
{
g.FillRectangle(new SolidBrush(Color.Orange), rect);
g.DrawRectangle(new Pen(Color.Black), rect);
g.DrawString(name + " Адрес " + adress + " Размер " + size,
new Font("Arial", 9), new SolidBrush(Color.Black),
rect.Location);
}
}
private void button1_Click(object sender, EventArgs e)//размещение
страницы
{
bool temp = false;
for (int i = 0; i < binaryvector.Length; i++)
{
if (binaryvector[i].Busy == false)
{
binaryvector[i].Name = "Страница " + count;
binaryvector[i].Busy = true;
listBox1.Items.Add(binaryvector[i].Adress);
temp = true;
break;
}
}
if (temp == false)
{
Random rnd = new Random();
int r = rnd.Next(0, binaryvector.Length);
binaryvector[r].Name = "Страница " + count;
}
count++;
pictureBox1.Refresh();
button2.Enabled = true;
listBox1.Enabled = true; ;
}
private void button2_Click(object sender, EventArgs e)//удаление
(освобождение) страницы
{
for (int i = 0; i < binaryvector.Length; i++)
{
if (Convert.ToInt32(listBox1.SelectedItem) ==
Convert.ToInt32(binaryvector[i].Adress))
{
listBox1.Items.Remove(Convert.ToInt32
(binaryvector[i].Adress));
binaryvector[i].Busy = false;
pictureBox1.Refresh();
}
}
bool temp = false;
for (int i = 0; i < binaryvector.Length; i++)
{
if (binaryvector[i].Busy == true)
{
temp = true;
}
}
if (temp == false)
{
button2.Enabled = false;
listBox1.Enabled = false;
}
}
private void Form1_Paint(object sender, PaintEventArgs e)//отображение
АП ОП
{
e.Graphics.DrawString("0", new Font("Arial", 9),
new SolidBrush(Color.Black), pictureBox1.Location.X - 10,
pictureBox1.Location.Y - 10);
e.Graphics.DrawString(Convert.ToString(APOPsize), new Font("Arial",
9), new SolidBrush(Color.Black), pictureBox1.Location.X - 25,
pictureBox1.Location.Y + pictureBox1.Height);
}
private void pictureBox1_Paint(object sender,
PaintEventArgs e)//отображение страниц
{
if (binaryvector.Length != 0)
{
for (int i = 0; i < binaryvector.Length; i++)
{
if (binaryvector[i].Busy == true)
{
binaryvector[i].Draw(e.Graphics);
}
}
}
}
private void button3_Click(object sender, EventArgs e)//освобождение АП
{
button1.Enabled = false;
button4.Enabled = false;
comboBox2.Enabled = false;
button5.Enabled = true;
comboBox1.Enabled = true;
button2.Enabled = false;
listBox1.Enabled = false;
listBox1.Items.Clear();
for (int i = 0; i < binaryvector.Length; i++)
{
binaryvector[i].Busy = false;
}
count = 0;
pictureBox1.Refresh();
}
private void button4_Click(object sender, EventArgs e)//задание размер
страниц
{
size = Convert.ToInt32(comboBox2.SelectedItem);
if (size <= APOPsize)
{
binaryvector = new Page[APOPsize / size];
for (int i = 0; i < binaryvector.Length; i++)
{
binaryvector[i] = new Page(i * size, size,
new Rectangle(new Point(0, i * pictureBox1.Height /
binaryvector.Length), new Size(pictureBox1.Width,
pictureBox1.Height / binaryvector.Length)));
}
button4.Enabled = false;
comboBox2.Enabled = false;
button1.Enabled = true;
}
else MessageBox.Show("Размер страницы должен быть меньше
размера адресного пространства");
}
private void button5_Click(object sender, EventArgs e)//задание размера
АП
{
APOPsize = Convert.ToInt32(comboBox1.SelectedItem);
this.Refresh();
button5.Enabled = false;
comboBox1.Enabled = false;
button4.Enabled = true;
comboBox2.Enabled = true;
}
}
}
Размещено на Allbest.ru
Подобные документы
Схема распределения памяти, соответствующая пользовательской трактовке распределения памяти. Перемещение с помощью таблицы сегментов. Аппаратная поддержка сегментного распределения памяти. Сегментно-страничная организация памяти с двухуровневой схемой.
лекция [1,5 M], добавлен 24.01.2014Объем двухпортовой памяти, расположенной на кристалле, для хранения программ и данных в процессорах ADSP-2106x. Метод двойного доступа к памяти. Кэш-команды и конфликты при обращении к данным по шине памяти. Пространство памяти многопроцессорной системы.
реферат [28,1 K], добавлен 13.11.2009Классификация компьютерной памяти. Использование оперативной, статической и динамической оперативной памяти. Принцип работы DDR SDRAM. Форматирование магнитных дисков. Основная проблема синхронизации. Теория вычислительных процессов. Адресация памяти.
курсовая работа [1,5 M], добавлен 28.05.2016Внутренний кэш. Смешанная и разделенная кэш-память. Статическая и динамическая память. TLB как разновидность кэш-памяти. Организация кэш-памяти. Отображение секторов ОП в кэш-памяти. Иерархическая модель кэш-памяти. Ассоциативность кэш-памяти.
курсовая работа [229,1 K], добавлен 04.11.2006Динамическое распределение памяти. Анализ виртуальной памяти, алгоритм ее обращения, общие принципы защиты. Страничная организация. Особенности переключения в мультизадачный режим. Режим системного управления. Расширение размера адресного пространства.
презентация [1,3 M], добавлен 14.12.2013Распределение виртуальной памяти. Страничная и сегментная организации виртуальной памяти. Сегментно-страничная организация виртуальной памяти. Преобразование виртуального адреса в физический. Упрощение адресации памяти клиентским программным обеспечением.
курсовая работа [440,7 K], добавлен 04.03.2014- Управление памятью. Страничная организация памяти. Сегментная организация памяти. Виртуальная память
Как осуществляется трансляция адресов при страничной организации. Что такое компактировка и как с ее помощью избавиться от внешней фрагментации. Что такое регистр таблицы страниц, сегментация. Методы распределения памяти в виде отдельных сегментов.
контрольная работа [236,2 K], добавлен 23.12.2016 Распределение оперативной памяти фиксированными, динамическими и перемещаемыми разделами. Распределение с использованием внешней памяти. Принципы рaботы матричного принтера. Проектирование символов и разработка программы, реализующей их вывод на печать.
курсовая работа [241,3 K], добавлен 01.07.2011Хранение различной информации как основное назначение памяти. Характеристика видов памяти. Память типа SRAM и DRAM. Кэш-память или сверхоперативная память, ее специфика и области применения. Последние новинки разработок в области в оперативной памяти.
презентация [2,1 M], добавлен 01.12.2014Простейшая схема взаимодействия оперативной памяти с ЦП. Устройство и принципы функционирования оперативной памяти. Эволюция динамической памяти. Модуль памяти EDO-DRAM BEDO (Burst EDO) - пакетная EDO RAM. Модуль памяти SDRAM, DDR SDRAM, SDRAM II.
реферат [16,1 K], добавлен 13.12.2009