_rotl
, _rotl64
, _rotr
, _rotr64
Rotiert Bits nach links (_rotl
) oder rechts (_rotr
).
Syntax
unsigned int _rotl(
unsigned int value,
int shift
);
unsigned __int64 _rotl64(
unsigned __int64 value,
int shift
);
unsigned int _rotr(
unsigned int value,
int shift
);
unsigned __int64 _rotr64(
unsigned __int64 value,
int shift
);
Parameter
value
Der zu rotierende Wert.
shift
Die Anzahl der zu verschiebenden Bits.
Rückgabewert
Der gedrehte Wert. Es wird kein Fehler zurückgegeben.
Hinweise
Die _rotl
Funktionen drehen _rotr
die nicht signierten value
Bits.shift
_rotl
rotiert den Wert nach links. _rotr
rotiert den Wert nach rechts. Beide Funktionen umschließen Bits, die von einem Ende zum value
anderen gedreht wurden.
Anforderungen
Routine | Erforderlicher Header |
---|---|
_rotl , _rotl64 |
<stdlib.h> |
_rotr , _rotr64 |
<stdlib.h> |
Weitere Informationen zur Kompatibilität finden Sie unter Kompatibilität.
Bibliotheken
Alle Versionen der C-Laufzeitbibliotheken.
Beispiel
// crt_rot.c
/* This program shifts values to rotate an integer.
*/
#include <stdlib.h>
#include <stdio.h>
int main( void )
{
unsigned val = 0x0fd93;
__int64 val2 = 0x0101010101010101;
printf( "0x%4.4x rotated left three times is 0x%4.4x\n",
val, _rotl( val, 3 ) );
printf( "0x%4.4x rotated right four times is 0x%4.4x\n",
val, _rotr( val, 4 ) );
printf( "%I64x rotated left three times is %I64x\n",
val2, _rotl64( val2, 3 ) );
printf( "%I64x rotated right four times is %I64x\n",
val2, _rotr64( val2, 4 ) );
}
Ausgabe
0xfd93 rotated left three times is 0x7ec98
0xfd93 rotated right four times is 0x30000fd9
101010101010101 rotated left three times is 808080808080808
101010101010101 rotated right four times is 1010101010101010
Siehe auch
Feedback
https://aka.ms/ContentUserFeedback.
Bald verfügbar: Im Laufe des Jahres 2024 werden wir GitHub-Issues stufenweise als Feedbackmechanismus für Inhalte abbauen und durch ein neues Feedbacksystem ersetzen. Weitere Informationen finden Sie unterFeedback senden und anzeigen für