Compartir a través de


_bittestandreset, _bittestandreset64

Específicos de Microsoft

Generar la instrucción que examina el bit b de la dirección a, devuelve su valor actual y restablece el bit a 0.

unsigned char _bittestandreset(    long *a,    long b ); unsigned char _bittestandreset64(    __int64 *a,    __int64 b );

Parámetros

  • [in, out] a
    Puntero a la memoria que se va a examinar.

  • [in] b
    La posición de bit que se va a probar.

Valor devuelto

El bit en la posición especificada.

Requisitos

Función intrínseca

Arquitectura

_bittestandreset

x86, ARM, x64

_bittestandreset64

x64

Archivo de encabezado <intrin.h>

Comentarios

Esta rutina solo está disponible como función intrínseca.

Ejemplo

// bittestandreset.cpp
// processor: x86, IPF, x64
#include <stdio.h>
#include <limits.h>
#include <intrin.h>

#pragma intrinsic(_bittestandreset)

// Check the sign bit and reset to 0 (taking the absolute value)
// Returns 0 if the number is positive or zero
// Returns 1 if the number is negative
unsigned char absolute_value(long* p)
{
   const int SIGN_BIT = 31;
   return _bittestandreset(p, SIGN_BIT);
}

int main()
{
    long i = -112;
    unsigned char result;
   
    // Check the sign bit and reset to 0 (taking the absolute value)

    result = absolute_value(&i);
    if (result == 1)
        printf_s("The number was negative.\n");   
}
  

Vea también

Referencia

Intrínsecos del controlador