он провалился несколько тысяч раз в день. < /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);
Я знаю, что 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