Где разница между событием wwait ascain и event.waitC#

Место общения программистов C#
Ответить
Anonymous
 Где разница между событием wwait ascain и event.wait

Сообщение Anonymous »

У меня есть драйвер связи.

он провалился несколько тысяч раз в день. < /p>
Но после изменения одной строки она теперь работает отлично. < /p>

Код: Выделить всё

// The event is set after 100ms at the latest
ManualResetEvent sendOutEvent = new ManualResetEvent(false);

...

// Before, it would sometimes get stuck here for over 800ms.
await Task.Run(() => outgoingPacket.sendOutEvent.WaitOne(5000));

// Replacing it with this line. It works as expected
outgoingPacket.sendOutEvent.WaitOne(5000);
Этот фрагмент кода вызывается примерно 1 миллион раз в день, но всегда ожидает завершения перед следующим вызовом.
Я знаю, что await конструкция является излишней, но даже в этом случае обе строки должны работать одинаково.

Я ожидаю, что await Task.Run будет медленнее, но не почти на 800 мс.Я что-то упустил, где находится разница?
Некоторые значения из отладки
Использование этого

Код: Выделить всё

    ThreadPool.GetAvailableThreads (out  int workerThreads, out int  portThreads);
Console.WriteLine($"workerThreads={workerThreads}, portThreads={portThreads} ThreadCount={ThreadPool.ThreadCount} CompletedWorkItemCount={ThreadPool.CompletedWorkItemCount} PendingWorkItemCount={ThreadPool.PendingWorkItemCount}");
Показывает это или подобные значения

workerThreads=32757, portThreads=1000 ThreadCount=20 CompletedWorkItemCount=413166 PendingWorkItemCount=0

Иногда я вижу PendingWorkItemCount > 0, но с максимум 20

Подробнее здесь: https://stackoverflow.com/questions/793 ... event-wait
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»