Freigeben über


cancellation_token-Klasse

Mit der cancellation_token-Klasse kann bestimmt werden, ob für einen Vorgang ein Abbruch angefordert wurde. Dem angegebenen Token kann task_group, structured_task_group oder task zugeordnet werden, um einen impliziten Abbruch bereitzustellen. Es kann auch zum Abbruch abgerufen oder für einen Rückruf registriert werden, wenn das zugeordnete cancellation_token_source-Element abgebrochen wird.

Syntax

class cancellation_token;

Member

Öffentliche Konstruktoren

Name Beschreibung
cancellation_token
~cancellation_token Destruktor

Öffentliche Methoden

Name Beschreibung
deregister_callback Entfernt einen Rückruf, der zuvor über die Methode register registriert wurde, auf Grundlage des cancellation_token_registration-Objekts, das zum Zeitpunkt der Registrierung zurückgegeben wurde.
is_cancelable Gibt einen Hinweis zurück, ob dieses Token abgebrochen werden kann oder nicht.
is_canceled Gibt zurück true , wenn das Token abgebrochen wurde.
none Gibt ein Abbruchtoken zurück, das nie abgebrochen werden kann.
register_callback Verknüpft eine Rückruffunktion mit dem Token. Wenn das Token abgebrochen wird, wird der Rückruf vorgenommen. Wurde das Token bereits abgebrochen, wenn diese Methode aufgerufen wird, wird der Rückruf sofort und synchron ausgeführt.

Öffentliche Operatoren

Name Beschreibung
operator!=
operator=
operator==

Vererbungshierarchie

cancellation_token

Anforderungen

Kopfzeile: pplcancellation_token.h

Namespace: Parallelität

~cancellation_token

~cancellation_token();

cancellation_token

cancellation_token(const cancellation_token& _Src);

cancellation_token(cancellation_token&& _Src);

Parameter

_Src
Die cancellation_token, die kopiert oder verschoben werden soll.

deregister_callback

Entfernt einen Rückruf, der zuvor über die Methode register registriert wurde, auf Grundlage des cancellation_token_registration-Objekts, das zum Zeitpunkt der Registrierung zurückgegeben wurde.

void deregister_callback(const cancellation_token_registration& _Registration) const;

Parameter

_Registrierung
Das cancellation_token_registration-Objekt für den Rückruf, dessen Registrierung aufgehoben werden soll. Dieses Token muss zuvor von einem Aufruf der register-Methode zurückgegeben worden sein.

is_cancelable

Gibt einen Hinweis zurück, ob dieses Token abgebrochen werden kann oder nicht.

bool is_cancelable() const;

Rückgabewert

Ein Hinweis darauf, ob dieses Token abgebrochen werden kann oder nicht.

is_canceled

Gibt zurück true , wenn das Token abgebrochen wurde.

bool is_canceled() const;

Rückgabewert

Der Wert true , wenn das Token abgebrochen wurde; andernfalls der Wert false.

keine

Gibt ein Abbruchtoken zurück, das nie abgebrochen werden kann.

static cancellation_token none();

Rückgabewert

Ein Abbruchtoken, das nicht abgebrochen werden kann.

operator!=

bool operator!= (const cancellation_token& _Src) const;

Parameter

_Src
Das zu vergleichende cancellation_token-Element.

Rückgabewert

operator =

cancellation_token& operator= (const cancellation_token& _Src);

cancellation_token& operator= (cancellation_token&& _Src);

Parameter

_Src
Der cancellation_token zugewiesen werden soll.

Rückgabewert

operator==

bool operator== (const cancellation_token& _Src) const;

Parameter

_Src
Das zu vergleichende cancellation_token-Element.

Rückgabewert

register_callback

Verknüpft eine Rückruffunktion mit dem Token. Wenn das Token abgebrochen wird, wird der Rückruf vorgenommen. Wurde das Token bereits abgebrochen, wenn diese Methode aufgerufen wird, wird der Rückruf sofort und synchron ausgeführt.

template<typename _Function>
::Concurrency::cancellation_token_registration register_callback(const _Function& _Func) const;

Parameter

_Funktion
Der Typ des Funktionsobjekts, das zurückgerufen wird, wenn dieses cancellation_token abgebrochen wird.

_Func
Das Funktionsobjekt, das zurückgerufen wird, wenn dieses cancellation_token abgebrochen wird.

Rückgabewert

Ein cancellation_token_registration-Objekt, das in der deregister-Methode verwendet werden kann, um einen bereits registrierten Rückruf aufzuheben, damit er nicht ausgeführt wird. Die Methode löst eine invalid_operation Ausnahme aus, wenn sie für ein cancellation_token Objekt aufgerufen wird, das mit der methode cancellation_token::none erstellt wurde.

Siehe auch

Concurrency-Namespace