_rotl, _rotl64, _rotr, _rotr64
Fait pivoter des bits vers la gauche (_rotl) ou la droite (_rotr).
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
);
Paramètres
correspondante
valeur à faire pivoter.shift
Nombre de bits à déplacer.
Valeur de retour
la valeur pivotée.Il n'existe aucun retour d'erreur.
Notes
Les fonctions d' _rotl et d' _rotr rotation la valeur non signée par des bits d' shift ._rotl fait pivoter la valeur autorisée._rotr fait pivoter la droite de valeur.Les deux bits d'enveloppe de fonctions tournés et une fin de la valeur à l'autre extrémité.
Configuration requise
routine |
en-tête requis |
---|---|
_rotl, _rotl64 |
<stdlib.h> |
_rotr, _rotr64 |
<stdlib.h> |
Pour plus d'informations de compatibilité, consultez compatibilité dans l'introduction.
bibliothèques
toutes les versions de Bibliothèques runtime C.
Exemple
// 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 ) );
}
Sortie
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
Équivalent .NET Framework
Non applicable. Pour appeler la fonction C standard, utilisez PInvoke. Pour plus d'informations, consultez l' exemples d'appel de code non managé.