#c# #iasyncresult
#c# #iasyncresult
Вопрос:
В некоторых реализациях WaitAll я видел следующий код
IAsyncResult result1 = Method.BeginInvoke(10, MyCallback, null)
IAsyncResult result2 = Method.BeginInvoke(20, MyCallback, null)
WaitHandle[] waitHandles = new WaitHandle[] { result1.AsyncWaitHandle, result2.AsyncWaitHandle};
WaitHandle.WaitAll(waitHandles)
Кажется ли это правильным? Каковы шансы, что до создания массива WaitHandles один из вызовов завершится?
С уважением, Дхананджай
Ответ №1:
Для меня это имеет смысл.
// Begin invoking the first and second method, and give them a callback
IAsyncResult result1 = Method.BeginInvoke(10, MyCallback, null)
IAsyncResult result2 = Method.BeginInvoke(20, MyCallback, null)
// Any time past the point of invokation, MyCallback could be called.
// Get the wait handles of the async results, regardless of whether they have finished or not
WaitHandle[] waitHandles = new WaitHandle[] { result1.AsyncWaitHandle, result2.AsyncWaitHandle};
// Make sure to wait until the methods have finished.
// They could have finished immediately, and MyCallback could have already been called,
// but we will never get past this line unless they have finished.
WaitHandle.WaitAll(waitHandles)
// We may have waited on the function to finish, or they may have been done before we arrived at the previous line. Either way, they are done now.
Что именно вы находите странным?
Спрашивать «каковы шансы» — плохой знак. Есть вероятность, что это может произойти, что означает, что вам нужно будет учитывать, что программа должна делать, если и когда методы завершатся до завершения работы WaitAll.
Комментарии:
1. Причина в том, что var result = del. Завершение вызова(ar);
2. EndInvoke также ожидает завершения асинхронного результата, но обратный вызов все еще мог быть вызван до достижения EndInvoke.