русс | укр

Языки программирования

ПаскальСиАссемблерJavaMatlabPhpHtmlJavaScriptCSSC#DelphiТурбо Пролог

Компьютерные сетиСистемное программное обеспечениеИнформационные технологииПрограммирование

Все о программировании


Linux Unix Алгоритмические языки Аналоговые и гибридные вычислительные устройства Архитектура микроконтроллеров Введение в разработку распределенных информационных систем Введение в численные методы Дискретная математика Информационное обслуживание пользователей Информация и моделирование в управлении производством Компьютерная графика Математическое и компьютерное моделирование Моделирование Нейрокомпьютеры Проектирование программ диагностики компьютерных систем и сетей Проектирование системных программ Системы счисления Теория статистики Теория оптимизации Уроки AutoCAD 3D Уроки базы данных Access Уроки Orcad Цифровые автоматы Шпаргалки по компьютеру Шпаргалки по программированию Экспертные системы Элементы теории информации

Управление потоками.


Дата добавления: 2013-12-23; просмотров: 1140; Нарушение авторских прав


1) Планирование потоков.

2) Синхронизация потоков.

В Windows реализована подсистема вытесняющего планирования на основе уровней приоритета. Всегда выполняется поток с наивысшим приоритетом к выполнению.

В многопроцессорных системах под Windows NT и Windows 2000 выбор потока для выполнения может быть ограничен набором процессоров, на которых он может работать. Этот метод называется привязкой к процессору (processor affinity). По умолчанию поток выполняется на любом процессоре. С помощью функций Win32 можно изменить привязку к процессорам.

Выбранный для выполнения поток работает в течение некоторого периода называемого квантом. После того, как истёк квант времени ОС будет искать другой поток с таким же уровнем приоритета или выше. Если таких нет, то ищет с меньшим приоритетом. В Windows 2000 потокам могут выделяться разные кванты времени. Поток также может не полностью использовать свой квант.

Как только другой поток с более высоким приоритетом готов к выполнению, текущий поток вытесняется даже если его квант не истёк.

Код Windows, отвечающий за планирование реализован в ядре ОС. Этот код рассредоточен по ядру, поэтому нет единого модуля или процедуры с названием планировщик. Совокупность процедур, выполняющих планирование называется диспетчером ядра.

 

Диспетчер ядра инициализируется следующими событиями.

1) Поток готов к выполнению, например, он только что создан или вышел из состояния ожидания.

2) Поток прекращает выполнение, когда его квант истёк или поток завершается, или поток переходит в состояние ожидания.

3) Приоритет потока изменяется, например, в результате вызова системного сервиса.

4) Изменяется привязка к процессорам выполняемого потока.

В любом из этих четырёх случаев Windows должна определить, какой поток должен выполняться следующим.



Выбрав новый поток Windows включает CONTEXT, текущее содержание регистров процессора переписывается в структуру CONTEXT, которая находится в TDB (ETHREAD).

Планирование в Windows осуществляется на уровне потоков, то есть ОС не волнует то, какому процессу принадлежит тот или иной поток.

Пример. Если у процесса А – 12 потоков, а у В – 2 потока, и все 14 потоков имеют один и тот же приоритет, то каждый поток получит 1/14 времени процессора. Windows не будет делить поровну время процессора между двумя процессами.

Уровни приоритета.

В Windows поддерживается 32 уровня приоритета от 0 до 31. Все приоритеты делятся на четыре класса. Класс приоритета присваивается процессу с помощью одного из флагов функции CreateProcess. Рассмотрим связь уровней приоритета с классами.

 

Класс Описание Флаг Уровень приоритета
Idle приостановлен IDLE_PRIORITY_CLASS
Normal нормальный NORMAL_PRIORITY_CLASS 7-9
High высокий HIGH_PRIORITY_CLASS
RealTime реального времени REALTIME_PRIORITY_CLASS

 

Если при вызове процесса класс Normal, то система присваивает процессу класс Normal, если только родительский процесс не имел класс Idle.

1) Idle. Используется для системного потока, который обнуляет неиспользованные страницы памяти. Этот класс может использовать, например, ScreenSaver. Большую часть времени этот поток отсле-живает деятельность пользователя. Если он не использует компьютер, то хранитель экрана активи-зируется.

2) Normal. В основном все процессы работают с этим классом проиритета. Windows 95, 98 сама по-вышает уровень приоритета активного процесса.

3) High. Его следует использовать в случае крайней необходимости, например, в Windows приоритет High имеет менеджер задач. Такой приоритет устанавливается, чтобы прервать любой поль-зовательский процесс, даже если он вышел в непрерывный цикл.

4) RealTime. Практически никогда не используется. В ранних версиях Windows этот класс отсут-ствовал. Его не стоит использовать, так как системные потоки, использующие клавиатуру и мышь имеют меньший приоритет. Его следует использовать в нескольких случаях.

- в приложении напрямую общаться с оборудованием, например в драйверах устройств.

- если приложение выполняет быстротечную операцию, которую нельзя прервать.

 



<== предыдущая лекция | следующая лекция ==>
Описание структур управления потоками. | Учёт квантов времени.


Карта сайта Карта сайта укр


Уроки php mysql Программирование

Онлайн система счисления Калькулятор онлайн обычный Инженерный калькулятор онлайн Замена русских букв на английские для вебмастеров Замена русских букв на английские

Аппаратное и программное обеспечение Графика и компьютерная сфера Интегрированная геоинформационная система Интернет Компьютер Комплектующие компьютера Лекции Методы и средства измерений неэлектрических величин Обслуживание компьютерных и периферийных устройств Операционные системы Параллельное программирование Проектирование электронных средств Периферийные устройства Полезные ресурсы для программистов Программы для программистов Статьи для программистов Cтруктура и организация данных


 


Не нашли то, что искали? Google вам в помощь!

 
 

© life-prog.ru При использовании материалов прямая ссылка на сайт обязательна.

Генерация страницы за: 0.003 сек.