_bittestandcomplement、_bittestandcomplement64

[このドキュメントはプレビュー版であり、後のリリースで変更されることがあります。 Blank topics are included as placeholders.]

Microsoft 固有の仕様 →

アドレスを返します a ビット b 現在の値をチェックしおよびにビットが設定されます btc 命令を生成します。

unsigned char _bittestandcomplement(
   long *a,
   long b
);
unsigned char _bittestandcomplement64(
   __int64 *a,
   __int64 b
);

パラメーター

  • [入力、出力] a
    チェックするメモリへのポインター。

  • [入力] b
    テストするビット位置。

戻り値

指定した位置のビット。

必要条件

組み込み

アーキテクチャ

_bittestandcomplement

x86IPFx64 

_bittestandcomplement64

はx64

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

解説

はアーキテクチャではbtc 命令は使用できないためこの組み込みでは btc の動作をシミュレートするカスタム関数です。 この関数はカスタム オーバーヘッドが含まれているため特定の場合は不要である可能性もある b が負の値である場合の処理など手書きのインライン関数より遅い場合があります。

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

使用例

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

#pragma intrinsic(_bittestandcomplement)
#ifdef _M_AMD64
#pragma intrinsic(_bittestandcomplement64)
#endif

int main()
{
   long i = 1;
   __int64 i64 = 0x1I64;
   unsigned char result;
   printf("Initial value: %d\n", i);
   printf("Testing bit 1\n");
   result = _bittestandcomplement(&i, 1);
   printf("Value changed to %d, Result: %d\n", i, result);
#ifdef _M_AMD64
   printf("Testing bit 0\n");
   result = _bittestandcomplement64(&i64, 0);
   printf("Value changed to %I64d, Result: %d\n", i64, result);
#endif
}

出力例

Initial value: 1
Testing bit 1
Value changed to 3, Result: 0
Testing bit 0
Value changed to 0, Result: 1

参照

Reference

コンパイラ組み込み関数。