_rotl
, _rotl64
, _rotr
, _rotr64
Gira bits para a esquerda (_rotl
) ou para a direita (_rotr
).
Sintaxe
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
);
Parâmetros
value
O valor a ser girado.
shift
O número de bits a deslocar.
Retornar valor
O valor girado. Não há retorno de erro.
Comentários
As _rotl
funções e _rotr
giram o não assinado value
por shift
bits. _rotl
gira o valor para a esquerda. _rotr
gira o valor para a direita. Ambas as funções encapsulam bits girados value
de uma extremidade para a outra extremidade.
Requisitos
Rotina | Cabeçalho necessário |
---|---|
_rotl , _rotl64 |
<stdlib.h> |
_rotr , _rotr64 |
<stdlib.h> |
Para obter informações sobre compatibilidade, consulte Compatibilidade.
Bibliotecas
Todas as versões das bibliotecas em tempo de execução C.
Exemplo
// 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 ) );
}
Saída
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
Confira também
Comentários
https://aka.ms/ContentUserFeedback.
Em breve: Ao longo de 2024, eliminaremos os problemas do GitHub como o mecanismo de comentários para conteúdo e o substituiremos por um novo sistema de comentários. Para obter mais informações, consulteEnviar e exibir comentários de