отмены? то есть типа Task.Delay(1000, ct), но чтобы когда cancel сработал, я не получил в лицо экзепшен?
ты можешь завести Task.Delay и еще один таск "отмены" потом вызвать их через Task.WhenAny если нужно отменить, то на таске отмены делаешь setresult, и из whenany выходит
Это какое то приседание с конями
оберни это в красивые абстракции и никто не узнает, что ты с конями приседаешь
Напиши свою таску с TaskCompletionSource. Вместо передачи cancelationToken внутрь, подпишись на отмену и дёргай SetResult.
Я делаю task when any и два таска заворачиваю. один обычный delay, второй - твоя таска. Фсе
щас набегут кокошеры и скажут что ты не диспозишь таймер
У меня нет второй таски , мне надо вызывать синхронный метод раз в секунду
``` async Task GracefulDelay(TimeSpan timeSpan, CancellationToken cancellationToken) { // ReSharper disable once MethodSupportsCancellation var delay = Task.Delay(1000); var tcs = new TaskCompletionSource(); cancellationToken.Register(() => { tcs.SetResult();}); await Task.WhenAny(tcs.Task, delay); } ```
а он тут будет?
Всмысле? Я в метод только токен передаю, остальное тестовая обвязка
а как ещё сделать асинхронный Delay?
Сорян, думал весь код на скриншоте
а я не знаю ) потому и спрашиваю. Смутно помню что там какой-то где-то магический колбек на тредпуле регается, но как работает хз. И кого диспоузить непонятно
var ct = new CompletionTaskSource(); WaitAny(Task.Delay(1000), ct.Task); ... ct.SetResult();
И получаешь lock contention на фреймворке
Обсуждают сегодня