книга DipMaster-Shop.RU
поиск
карта
почта
Главная На заказ Готовые работы Способы оплаты Партнерство Контакты F.A.Q. Поиск
Электронное правительство Словении 2009-22 ( Реферат, 22 стр. )
Электронные вычислительные машины, характеристика персональных компьютеров. Достоинства и недостатки этого класса ЭВМ ( Контрольная работа, 21 стр. )
ЭЛЕКТРОННЫЕ ДЕНЬГИ КАК ФАКТОР РАЗВИТИЯ ЭКОНОМИКИ РОССИИ В СОВРЕМЕННЫХ УСЛОВИЯХ ( Дипломная работа, 85 стр. )
Электронные магазины , электронные издания и электронные библиотеки ( Реферат, 17 стр. )
Электронные платежи ( Контрольная работа, 28 стр. )
Электронные платежные системы в сфере розничных расчетов ( Курсовая работа, 35 стр. )
Электронные презентации MS Power Point. Возможности создания и области использования ( Контрольная работа, 17 стр. )
Электронные ресурсы и издания ( Реферат, 13 стр. )
Электронные системы денежных расчетов ( Курсовая работа, 29 стр. )
Электронные системы платежей ( Дипломная работа, 71 стр. )
Электронные таблицы Microsoft Excel. СУБД MS Access ( Контрольная работа, 28 стр. )
Электронный бизнес как средство распространения информационных продуктов и услуг ( Дипломная работа, 154 стр. )
Электронный офис ( Реферат, 17 стр. )
Элементы технологии создания анимированных документов с помощью интеллектуальных форм ( Курсовая работа, 33 стр. )
Энтропия и количество информации ( Реферат, 22 стр. )
Эскизное проектирование модернизации физической и логической архитектуры локальной вычислительной сети предприятия ГУП НПЦ "ЭЛВИС" ( Дипломная работа, 60 стр. )
ЭТАПЫ И ПЕРСПЕКТИВЫ РАЗВИТИЯ ИНФОРМАЦИОННЫХ СИСТЕМ ( Курсовая работа, 36 стр. )
Этапы проектирования базы данных и их процедуры ( Реферат, 7 стр. )
Этапы развития информационных технологий ( Реферат, 11 стр. )
Этапы развития информационных технологий ( Контрольная работа, 13 стр. )
Этапы развития информационных технологий управления в России ( Реферат, 24 стр. )
Этапы развития информационных технологий 2004-19 ( Реферат, 19 стр. )
Этапы разработки автоматизированных информационных систем ( Курсовая работа, 33 стр. )
Этические проблемы информатизации и компьютеризации ( Реферат, 14 стр. )
ЭФФЕКТИВНОСТЬ И ПРОБЛЕМЫ РАЗВИТИЯ ПРАВОВОЙ ИНФОРМАТИЗАЦИИ В РЕСПУБЛИКЕ БЕЛАРУСЬ ( Дипломная работа, 28 стр. )

Содержание

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»