Je le sais Thread.Sleep
bloque un thread.
Mais Task.Delay
également bloquer? Ou est-ce juste comme Timer
qui utilise un thread pour tous les rappels (lorsqu'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
l'utilisation 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 n'est qu'un minuteur enveloppé dans une tâche. Alors oui, vous pouvez dire que c'est comme une minuterie.