InterlockedExchange16-Funktion (winnt.h)
Legt eine 16-Bit-Variable auf den angegebenen Wert als atomischen Vorgang fest.
Um mit einer 32-Bit-Variablen zu arbeiten, verwenden Sie die Funktion InterlockedExchange .
Verwenden Sie zum Arbeiten mit einer 64-Bit-Variablen die Funktion InterlockedExchange64 .
Syntax
SHORT InterlockedExchange16(
[in, out] SHORT volatile *Destination,
[in] SHORT ExChange
);
Parameter
[in, out] Destination
Ein Zeiger auf den wert, der ausgetauscht werden soll. Die Funktion legt diese Variable auf ExChange fest und gibt ihren vorherigen Wert zurück.
[in] ExChange
Der Wert, der mit dem Wert ausgetauscht werden soll, auf den das Ziel verweist.
Rückgabewert
Die Funktion gibt den Anfangswert des Destination-Parameters zurück.
Hinweise
Die ineinandergreifenden Funktionen bieten einen einfachen Mechanismus zum Synchronisieren des Zugriffs auf eine Variable, die von mehreren Threads gemeinsam genutzt wird. Diese Funktion ist in Bezug auf Aufrufe von anderen ineinandergreifenden Funktionen unteilbar.
Diese Funktion wird nach Möglichkeit mithilfe eines intrinsischen Compilers implementiert. Weitere Informationen finden Sie in der WinBase.h-Headerdatei und _InterlockedExchange16.
Diese Funktion generiert eine vollständige Speicherbarriere (oder einen Zaun), um sicherzustellen, dass Speichervorgänge in der richtigen Reihenfolge abgeschlossen werden.
Itanium-basierte Systeme: Verwenden Sie für leistungskritische Anwendungen stattdessen InterlockedExchangeAcquire64 .
Anforderungen
Anforderung | Wert |
---|---|
Unterstützte Mindestversion (Client) | Windows Vista [Desktop-Apps | UWP-Apps] |
Unterstützte Mindestversion (Server) | Windows Server 2003 [Desktop-Apps | UWP-Apps] |
Zielplattform | Windows |
Kopfzeile | winnt.h (windows.h einschließen) |
Weitere Informationen
Ineinandergreifen des Variablenzugriffs
InterlockedExchangePointerAcquire