книга DipMaster-Shop.RU
поиск
карта
почта
Главная На заказ Готовые работы Способы оплаты Партнерство Контакты F.A.Q. Поиск
Исследование программного обеспечения систем управления ( Контрольная работа, 12 стр. )
ИССЛЕДОВАНИЕ ПРОГРАММНОГО ОБЕСПЕЧЕНИЯ СИСТЕМ УПРАВЛЕНИЯ ( Контрольная работа, 15 стр. )
Исследование рекламных технологий в Интернет-пространстве ( Дипломная работа, 89 стр. )
Исследование сложностей, проблем, стратегии внедрения и использования ИТ в управлении предприятием ( Курсовая работа, 27 стр. )
Исследование средств синхронизации задач в операционной системе Microsoft Windows NT ( Курсовая работа, 42 стр. )
Исследование сферы использования классификаторов и кодов ( Реферат, 24 стр. )
Исследование сферы использования классификаторов и кодов 2001-24 ( Курсовая работа, 24 стр. )
Исследование технологии сетей беспроводной связи и разработка рекомендации по внедрению перспективных технологий связи стандартов четвертого поколения в России ( Дипломная работа, 107 стр. )
Исследование технологии проведения международных финансовых операций через интернет на примере ОАО "БИНБАНК" ( Дипломная работа, 85 стр. )
Исследование управленческих информационных систем, а также систем поддержки принятия решений и экспертных систем ( Курсовая работа, 31 стр. )
Исследование этапов ЖЦ ПС, а также программных, технологических, методологических и организационных средств обеспечения этих этапов ( Дипломная работа, 189 стр. )
Исследовать значение и существующую классификацию информации, в том числе и правовой ( Реферат, 19 стр. )
История 3Д графики. Основные понятия 3Д графики ( Курсовая работа, 30 стр. )
История возникновения справочно-правовых систем. Анализ рынка справочно-правовых систем. Критерии оценки справочно-правовых систем ( Реферат, 15 стр. )
История зарождения ЭВМ ( Реферат, 26 стр. )
История зарождения ЭВМ. Исчисление компьютера, двоичные и шестнадцатеричные системы. Арифметические операции, таблицы кодирования символов ( Курсовая работа, 26 стр. )
История и современные версии Windows ( Контрольная работа, 18 стр. )
История мониторов, их видов и параметров безопасности ( Контрольная работа, 29 стр. )
ИСТОРИЯ ПОЯВЛЕНИЯ И РАЗВИТИЯ ПОНЯТИЯ "ФРАКТАЛЬНОЕ СЖАТИЕ ИЗОБРАЖЕНИЙ" 2010-31 ( Курсовая работа, 31 стр. )
ИСТОРИЯ ПОЯВЛЕНИЯ И РАЗВИТИЯ ПОНЯТИЯ "ФРАКТАЛЬНОЕ СЖАТИЕ ИЗОБРАЖЕНИЙ" ( Курсовая работа, 31 стр. )
История развития Microsoft ( Реферат, 23 стр. )
История развития компьютера. Влияние на социально-общественное и культурное развитие. 456 ( Курсовая работа, 25 стр. )
История развития персональных компьютеров ( Дипломная работа, 72 стр. )
История развития ЭВМ и устройство компьютера ( Реферат, 21 стр. )
История развития ЭВМ. Архитектура современного персонального компьютера ( Реферат, 11 стр. )

Содержание

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»