Je sais que Thread.Sleep
bloque un fil.
Mais Task.Delay
bloque-t-il également? Ou est-ce juste comme Timer
qui utilise un thread pour tous les rappels (quand ils ne se chevauchent pas)?
( cette question ne couvre pas les différences)
Je sais que Thread.Sleep
bloque un fil.
Mais Task.Delay
bloque-t-il également? Ou est-ce juste comme Timer
qui utilise un thread pour tous les rappels (quand ils ne se chevauchent pas)?
( cette question ne couvre pas les différences)
La documentation sur MSDN est décevante, mais la décompilation Task.Delay
aide de Reflector donne plus d’informations:
public static Task Delay(int millisecondsDelay, CancellationToken cancellationToken)
{
if (millisecondsDelay < -1)
{
throw new ArgumentOutOfRangeException("millisecondsDelay", Environment.GetResourceString("Task_Delay_InvalidMillisecondsDelay"));
}
if (cancellationToken.IsCancellationRequested)
{
return FromCancellation(cancellationToken);
}
if (millisecondsDelay == 0)
{
return CompletedTask;
}
DelayPromise state = new DelayPromise(cancellationToken);
if (cancellationToken.CanBeCanceled)
{
state.Registration = cancellationToken.InternalRegisterWithoutEC(delegate (object state) {
((DelayPromise) state).Complete();
}, state);
}
if (millisecondsDelay != -1)
{
state.Timer = new Timer(delegate (object state) {
((DelayPromise) state).Complete();
}, state, millisecondsDelay, -1);
state.Timer.KeepRootedWhileScheduled();
}
return state;
}
Fondamentalement, cette méthode est juste une minuterie intégrée à une tâche. Alors oui, vous pouvez dire que c'est juste comme une minuterie.
Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.