CancellationToken.IsCancellationRequested Proprietà
Definizione
Importante
Alcune informazioni sono relative alla release non definitiva del prodotto, che potrebbe subire modifiche significative prima della release definitiva. Microsoft non riconosce alcuna garanzia, espressa o implicita, in merito alle informazioni qui fornite.
Ottiene un valore che indica se per questo token è stato richiesto l'annullamento.
public:
property bool IsCancellationRequested { bool get(); };
public bool IsCancellationRequested { get; }
member this.IsCancellationRequested : bool
Public ReadOnly Property IsCancellationRequested As Boolean
Valore della proprietà
true
se per questo token è stato richiesto l'annullamento; in caso contrario false
.
Esempio
Di seguito è riportato un semplice esempio che esegue un processo server fino a quando la IsCancellationRequested proprietà non restituisce true
.
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.
Imports System.Threading
Public Class ServerClass
Public Shared Sub StaticMethod(obj As Object)
Dim ct AS CancellationToken = CType(obj, CancellationToken)
Console.WriteLine("ServerClass.StaticMethod is running on another thread.")
' Simulate work that can be canceled.
While Not ct.IsCancellationRequested
Thread.SpinWait(50000)
End While
Console.WriteLine("The worker thread has been canceled. Press any key to exit.")
Console.ReadKey(True)
End Sub
End Class
Public Class Simple
Public Shared Sub Main()
' The Simple class controls access to the token source.
Dim cts As New CancellationTokenSource()
Console.WriteLine("Press 'C' to terminate the application..." + vbCrLf)
' Allow the UI thread to capture the token source, so that it
' can issue the cancel command.
Dim t1 As New Thread( Sub()
If Console.ReadKey(true).KeyChar.ToString().ToUpperInvariant() = "C" Then
cts.Cancel()
End If
End Sub)
' ServerClass sees only the token, not the token source.
Dim t2 As New Thread(New ParameterizedThreadStart(AddressOf 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()
End Sub
End Class
' 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.
Nell'esempio viene creata un'istanza di un CancellationTokenSource oggetto , che controlla l'accesso al token di annullamento. Definisce quindi due procedure di thread. Il primo viene definito come espressione lambda che esegue il pool della tastiera e, quando viene premuto il tasto "C", chiama CancellationTokenSource.Cancel per impostare il token di annullamento sullo stato annullato. Il secondo è un metodo con parametri, ServerClass.StaticMethod
, che esegue un ciclo fino a quando la IsCancellationRequested proprietà non è true
.
Il thread principale avvia quindi i due thread e si blocca finché il thread che esegue il ServerClass.StaticMethod
metodo termina.
Commenti
Questa proprietà indica se l'annullamento è stato richiesto per questo token, tramite il token inizialmente costruito in uno stato annullato o tramite la chiamata Cancel all'oggetto associato CancellationTokenSourceal token.
Se questa proprietà è true
, garantisce solo che sia stato richiesto l'annullamento. Non garantisce che ogni gestore registrato abbia terminato l'esecuzione, né che le richieste di annullamento siano state propagate a tutti i gestori registrati. Potrebbe essere necessaria una sincronizzazione aggiuntiva, in particolare nelle situazioni in cui gli oggetti correlati vengono annullati contemporaneamente.