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





Легенда:
  новое сообщение
  закрытая нитка
  новое сообщение
  в закрытой нитке
  старое сообщение
  • Напоминаю, что масса вопросов по функционированию форума снимается после прочтения его описания.
  • Новичкам также крайне полезно ознакомиться с данным документом.
[Win32] Ну и ну... 21.09.07 06:31  Число просмотров: 3078
Автор: void <Grebnev Valery> Статус: Elderman
<"чистая" ссылка>
Заработало если после поджигания Event-a поставить Sleep(0):

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

Причём Sleep(0) не всегда помогает. Чаще помогает Sleep(10), что в принципе не приемлимо (с какой стати я должен ждать). Т.е. кернел просто не успевает поднять пул потоков при поджигании ивента ИЛИ кернел поднимает пул, но поток из пула не успевает переключиться.
Есть ли предложения, как повысить гарантии вызова WaitCallback( PVOID lpParameter, BOOLEAN TimerOrWaitFired ) ?
<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