информационная безопасность
без паники и всерьез
 подробно о проектеRambler's Top100
Атака на InternetВсе любят медСтрашный баг в Windows
BugTraq.Ru
Русский BugTraq
 Анализ криптографических сетевых... 
 Модель надежности двухузлового... 
 Специальные марковские модели надежности... 
 Ядро Linux избавляется от российских... 
 20 лет Ubuntu 
 Tailscale окончательно забанила... 
главная обзор RSN блог библиотека закон бред форум dnet о проекте
bugtraq.ru / форум / programming
Имя Пароль
ФОРУМ
если вы видите этот текст, отключите в настройках форума использование JavaScript
регистрация





Легенда:
  новое сообщение
  закрытая нитка
  новое сообщение
  в закрытой нитке
  старое сообщение
  • Напоминаю, что масса вопросов по функционированию форума снимается после прочтения его описания.
  • Новичкам также крайне полезно ознакомиться с данным документом.
ну вообще-то такое часто случается с функциями синхронизации 21.09.07 13:45  Число просмотров: 2988
Автор: dl <Dmitry Leonov>
Отредактировано 21.09.07 13:47  Количество правок: 1
<"чистая" ссылка>
Скажем, если сбросить эвент сразу после взвода, нет никаких гарантий, что его успеют обработать. Так что всякие сбросы и unregister желательно перемещать к точке обработки.
<programming>
[Win32] RegisterWaitForSingleObject не зовёт callback 20.09.07 06:21  
Автор: void <Grebnev Valery> Статус: Elderman
<"чистая" ссылка>
Хочу позвать WaitCallback при зажигании evClientCompletedTest. Не печатает. Как быть?
Спасибо.

VOID CALLBACK WaitCallback( PVOID lpParameter, BOOLEAN TimerOrWaitFired )
{
_tprintf(_T("WaitCallback"));
}

...
...
..
void SomeFunc ( void )

HANDLE evClientCompletedTest = CreateEvent( NULL, FALSE, FALSE, NULL );

if ( NULL == evClientCompletedTest ) {
_tprintf(_T("CreateEvent failed (%d)\n"), GetLastError());
return false;
}


HANDLE hNewWaitObject = NULL;

if ( ! RegisterWaitForSingleObject(
&hNewWaitObject,
evClientCompletedTest,
WaitCallback,
NULL, INFINITE, WT_EXECUTEINWAITTHREAD ) ) {
_tprintf(_T("RegisterWaitForSingleObject() failed (%d)\n"), GetLastError());
return false;
}

SetEvent( evClientCompletedTest );

if ( !UnregisterWait( hNewWaitObject )) {
_tprintf(_T("UnregisterWait() failed (%d)\n"), GetLastError());
return false;
}

...
}
[Win32] Ну и ну... 21.09.07 06:31  
Автор: void <Grebnev Valery> Статус: Elderman
<"чистая" ссылка>
Заработало если после поджигания Event-a поставить Sleep(0):

...
...
SetEvent( evClientCompletedTest );
Sleep(0);
if ( !UnregisterWait( hNewWaitObject )) {
...

Причём Sleep(0) не всегда помогает. Чаще помогает Sleep(10), что в принципе не приемлимо (с какой стати я должен ждать). Т.е. кернел просто не успевает поднять пул потоков при поджигании ивента ИЛИ кернел поднимает пул, но поток из пула не успевает переключиться.
Есть ли предложения, как повысить гарантии вызова WaitCallback( PVOID lpParameter, BOOLEAN TimerOrWaitFired ) ?
ну вообще-то такое часто случается с функциями синхронизации 21.09.07 13:45  
Автор: dl <Dmitry Leonov>
Отредактировано 21.09.07 13:47  Количество правок: 1
<"чистая" ссылка>
Скажем, если сбросить эвент сразу после взвода, нет никаких гарантий, что его успеют обработать. Так что всякие сбросы и unregister желательно перемещать к точке обработки.
1




Rambler's Top100
Рейтинг@Mail.ru


  Copyright © 2001-2024 Dmitry Leonov   Page build time: 0 s   Design: Vadim Derkach