книга DipMaster-Shop.RU
поиск
карта
почта
Главная На заказ Готовые работы Способы оплаты Партнерство Контакты F.A.Q. Поиск
Характеристики основных модулей ПК. Некоторые дополнительные модули ПК ( Курсовая работа, 25 стр. )
ЦБС - виды, особенности, задачи, назначение, перспективы ( Контрольная работа, 49 стр. )
Цели и задачи информационных технологий в современном менеджменте. 2010-39 ( Курсовая работа, 39 стр. )
Цели и задачи информационных технологий в современном менеджменте. ( Курсовая работа, 39 стр. )
Целью данной работы является разработка базы данных «Анализ затрат» в СУБД Access ( Контрольная работа, 18 стр. )
Ценности и функции имиджа в теоретическом плане и на примере транспортной организации ( Контрольная работа, 12 стр. )
Циклические алгоритмы ( Контрольная работа, 15 стр. )
Челябинские дилеры программных продуктов ( Реферат, 12 стр. )
Что такое Internet? Услуги сети Internet. Броузер Internet Explorer ( Курсовая работа, 38 стр. )
Что такое информационное обслуживание ( Контрольная работа, 13 стр. )
Что такое управление знаниями (УЗ)? Перспективы применения УЗ в бизнесе ( Контрольная работа, 13 стр. )
Что такое ЭИС и ее основные элементы? ( Контрольная работа, 17 стр. )
ЭВМ Классификация ( Контрольная работа, 21 стр. )
Эволюция ПК ( Курсовая работа, 29 стр. )
Экзаменационные билеты по курсу "Операционные системы" ( Контрольная работа, 25 стр. )
Экзаменационные билеты по курсу "Операционные системы". ( Контрольная работа, 25 стр. )
Экономическая информационная система ( Контрольная работа, 17 стр. )
Экономическая информация как часть информационного ресурса общества ( Контрольная работа, 37 стр. )
Экономические и идеологические факторы формирования культуры в эпоху глобализации и Интернета ( Курсовая работа, 35 стр. )
Экономические информационные системы учета ( Контрольная работа, 19 стр. )
ЭКОНОМИЧЕСКИЕ ИНФОРМАЦИОННЫЕ СИСТЕМЫ ( Контрольная работа, 13 стр. )
Экономические информационные системы учета. Создание HTML – документов ( Контрольная работа, 14 стр. )
Экономические информационные системы учета. Создание HTML-документа. ( Контрольная работа, 18 стр. )
Экономические информационные системы учета. Создание HTML-документа ( Контрольная работа, 17 стр. )
ЭКОНОМИЧЕСКИЕ КРИЗИСЫ ( Курсовая работа, 34 стр. )

Содержание

1. Введение…………………………………………………………………3

1.1. Понятия процессов и задач в Windows NT…………………..……3

1.2. Проблемы синхронизации процессов и задач ……………………3

1.3. Техническое задание………………………………………………..4

2. Анализ средств синхронизации в Windows NT……………………..5

2.1. Ожидание завершения задачи или процесса………………………5

2.2. Использование событий…………………………………………….6

2.3. Критические секции…………………………………………………9

2.4. Объекты Mutex…………………………………………………..….11

2.5. Семафоры……………………………………………………………12

3. Оценка работы задач при синхронизации………………………….15

4. Разработка многозадачного приложения для Windows NT, исследующего различные виды синхронизации…………………..17

4.1. Структурно-функциональная организация приложения……..…..17

4.2. Описание отдельных модулей………………………………….….17

4.3. Результаты работы программы и их анализ…………………..…..20

5. Приложение. Документация сопровождения программы……..…25

6. Список литературы…………………………………………………….42

1. Введение

1.1. Понятия процессов и задач в Windows NT

В ОС Windows NT существует два понятия, имеющие отношение к мультизадачности. Это процессы и задачи (нити).

Процесс (process) создаётся, когда программа загружается в память для выполнения. Каждому процессу выделяется в монопольное владение 2 Гбайт изолированного адресного пространства, в которое другие процессы не имеют никакого доступа.

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

Следовательно, в ОС Microsoft Windows NT могут работать одновременно несколько процессов и в рамках каждого процесса могут параллельно работать несколько задач.

1.2. Проблемы синхронизации процессов и задач

В любой многозадачной системе проблема синхронизации встает, как только система позволяет иметь одновременный доступ к объектам. Вся теория синхронизации была разработана в 60-х–начале 70-х годов Деккером (Dekker), Дейкстрой (Dijkstra) и другими.

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

Здесь возможно очень много вариантов. Например, главная задача создает задачу, которая выполняет какую-либо длительную работу, например подсчет страниц в текстовом документе. Если теперь потребуется отобразить количество страниц на экране, главная задача должна дождаться завершения работы, выполняемой созданной задачей.

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

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

Поскольку выполняются, собственно, не процессы, а потоки, есть смысл говорить лишь о взаимодействии и синхронизации именно потоков, принадлежащих как одному процессу, так и разным. Только в одном случае можно упомянуть о взаимодействии именно процессов. Дескриптор процесса является сам по себе объектом синхронизации, и в этом смысле один процесс может ожидать завершения другого процесса (и таким образом синхронизироваться).

В программном интерфейсе ОС Windows NT предусмотрены различные средства синхронизации задач, как выполняющиеся в рамках одного процесса, так и принадлежащих разным процессам. Это средства организации последовательного использования ресурсов (mutex), критические секции (critical section), семафоры (semaphore), и события (event).

1.3. Техническое задание

Исследовать средства синхронизации задач в мультизадачной ОС Microsoft Windows NT. Продемонстрировать различные способы синхронизации на примере. Для этого необходимо написать приложение, в котором с помощью различных средств синхронизации синхронизируются действия нескольких нитей (задач). Результат работы программы представить в виде временной диаграммы, которая отражает применение средств синхронизации.

6. Список литературы

1. А.В.Фролов, Г.В.Фролов. Программирование для Windows NT. М.,1996.

1. Ю.Тихомиров. Vicual C++ 6. СПб, 1998.

2. М.Хаймен. Borland C++ для “чайников”. Киев, 1995.

3. С.О.Бочков, Д.М.Субботин. Язык программирования СИ для персонального компьютера. М., 1990

Виртуальные ресурсы:

Центр информационных технологий (раздел - сетевые ОС):

http://citforum.ru/operating_systems/sos/contents.shtml

Примечаний нет.

2000-2024 © Copyright «DipMaster-Shop.ru»