Иллюстрированный самоучитель по Visual Studio.Net




Механизмы синхронизации - часть 2


  • Обращаться к объекту ядра надо через описатель (handle), который система дает при создании объекта.

  • Каждый объект может находиться в одном из двух состояний: свободном (signaled) и занятом (nonsignaled).

    Синхронизация потоков развивается по такому сценарию. При засыпании одного из них операционная система перестает выделять ему кванты процессорного времени, приостанавливая его выполнение. Прежде чем заснуть, поток сообщает системе то особое событие, которое должно разбудить его. Как только указанное событие произойдет, система возобновит выдачу ему квантов процессорного времени и ноток вновь получит право на жизнь. Потоки усыпляют себя до освобождения какого-либо синхронизирующего объекта с помощью двух функций:

    DWORD WaitForSingleObject (HANDLE hObject, DWORD dwTimeOut);

    DWORD WaitForMultipleObjects(DWORD nCount,

    CONST HANDLE* lpHandles, BOOL bWaitAll,

    DWORD dwTimeOut);

    Первая функция приостанавливает поток до тех пор, пока или заданный параметром hObject синхронизирующий объект не освободится, или пока не истечет интервал времени, задаваемый параметром dwTimeOut. Если указанный объект в течение заданного интервала не перейдет в свободное состояние, то система вновь активизирует поток и он продолжит свое выполнение. В качестве параметра dwTimeOut могут выступать два особых значения:

    Таблица 12.3. Значения, выступающие в качестве параметра dwTimeOut

    В соответствии с причинами, по которым поток продолжает выполнение, функция WaitForSingleObject может возвращать одно из следующих значений:

    Таблица 12.4. Возвращение значений функцией WaitForSingleObject

    Функция WaitForMultipleObjects задерживает поток и в зависимости от значения флага bWaitAll ждет одного из следующих событий:

  • освобождение хотя бы одного синхронизирующего объекта из заданного списка;
  • освобождение всех указанных объектов;
  • истечение заданного интервала времени.



  • Содержание  Назад  Вперед