_bittestandreset、_bittestandreset64

Microsoft 固有の仕様

アドレス a のビット b を調べて現在の値を返し、そのビットを 0 にリセットする命令を生成します。

構文

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

パラメーター

a
[in, out] 検査するメモリを指すポインター。

b
[in] テストするビット位置。

戻り値

指定した位置にあるビット。

必要条件

Intrinsic アーキテクチャ
_bittestandreset x86、ARM、x64、ARM64
_bittestandreset64 x64、ARM64

ヘッダー ファイル<intrin.h>

解説

このルーチンは、組み込みとしてのみ使用できます。

// 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");
}
The number was negative.

Microsoft 固有の仕様はここまで

関連項目

コンパイラの組み込み