Прочитать на английском

Поделиться через


CancellationToken.IsCancellationRequested Свойство

Определение

Возвращает значение, указывающее, есть ли для данного токена запрос на отмену.

C#
public bool IsCancellationRequested { get; }

Значение свойства

Значение true, если для данного токена есть запрос на отмену; в противном случае — значение false.

Примеры

Ниже приведен простой пример выполнения серверного процесса до тех пор, пока свойство не IsCancellationRequested вернет true.

C#
using System;
using System.Threading;

public class ServerClass
{
   public static void StaticMethod(object obj)
   {
      CancellationToken ct = (CancellationToken)obj;
      Console.WriteLine("ServerClass.StaticMethod is running on another thread.");

      // Simulate work that can be canceled.
      while (!ct.IsCancellationRequested) {
         Thread.SpinWait(50000);
      }
      Console.WriteLine("The worker thread has been canceled. Press any key to exit.");
      Console.ReadKey(true);
   }
}

public class Simple
{
   public static void Main()
   {
      // The Simple class controls access to the token source.
      CancellationTokenSource cts = new CancellationTokenSource();

      Console.WriteLine("Press 'C' to terminate the application...\n");
      // Allow the UI thread to capture the token source, so that it
      // can issue the cancel command.
      Thread t1 = new Thread(() => { if (Console.ReadKey(true).KeyChar.ToString().ToUpperInvariant() == "C")
                                     cts.Cancel(); } );

      // ServerClass sees only the token, not the token source.
      Thread t2 = new Thread(new ParameterizedThreadStart(ServerClass.StaticMethod));
      // Start the UI thread.

      t1.Start();

      // Start the worker thread and pass it the token.
      t2.Start(cts.Token);

      t2.Join();
      cts.Dispose();
   }
}
// The example displays the following output:
//       Press 'C' to terminate the application...
//
//       ServerClass.StaticMethod is running on another thread.
//       The worker thread has been canceled. Press any key to exit.

В примере создается экземпляр объекта , который управляет доступом CancellationTokenSource к маркеру отмены. Затем он определяет две процедуры потока. Первый определяется как лямбда-выражение, которое объединяет клавиатуру и при нажатии клавиши "C" вызывает CancellationTokenSource.Cancel , чтобы установить для маркера отмены состояние отменено. Второй — параметризованный метод , который выполняет цикл до тех пор, ServerClass.StaticMethodпока свойство не IsCancellationRequested будет равно true.

Затем основной поток запускает два потока и блоки, пока поток, выполняющий ServerClass.StaticMethod метод, не завершится.

Комментарии

Это свойство указывает, была ли запрошена отмена для этого маркера либо с помощью маркера, изначально созданного в отмененном состоянии, либо путем вызова Cancel для связанного маркера CancellationTokenSource.

Если это свойство имеет значение true, это гарантирует только то, что была запрошена отмена. Он не гарантирует, что выполнение каждого зарегистрированного обработчика завершено, а запросы на отмену не будут распространяться на все зарегистрированные обработчики. Может потребоваться дополнительная синхронизация, особенно в ситуациях, когда связанные объекты отменяются одновременно.

Применяется к

Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9, 10
.NET Framework 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

См. также раздел