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





Легенда:
  новое сообщение
  закрытая нитка
  новое сообщение
  в закрытой нитке
  старое сообщение
  • Напоминаю, что масса вопросов по функционированию форума снимается после прочтения его описания.
  • Новичкам также крайне полезно ознакомиться с данным документом.
ну вообще-то такое часто случается с функциями синхронизации 21.09.07 13:45  Число просмотров: 3157
Автор: 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-2025 Dmitry Leonov   Page build time: 0 s   Design: Vadim Derkach