次の方法で共有


_BitScanForward、_BitScanForward64

Microsoft 固有の仕様

マスク データの最下位ビット (LSB) から最上位ビット (MSB) に向かって設定済みビット (1) を検索します。

構文

unsigned char _BitScanForward(
   unsigned long * Index,
   unsigned long Mask
);
unsigned char _BitScanForward64(
   unsigned long * Index,
   unsigned __int64 Mask
);

パラメーター

インデックス
[out] 最初に見つかった設定済みビット (1) のビット位置が読み込まれます。

Mask
[in] 検索する 32 ビットまたは 64 ビットの値。

戻り値

マスクが 0 の場合は 0。それ以外の場合は 0 以外。

解説

セット ビットが見つかった場合、最初のセット ビットのビット位置は、最初のパラメーターで指定されたアドレスに書き込まれ、関数は 1 を返します。 ビットが見つからない場合、関数は 0 を返し、最初のパラメーターのアドレスに書き込まれた値は未定義です。

要件

Intrinsic Architecture
_BitScanForward x86、ARM、x64、ARM64
_BitScanForward64 ARM64、x64

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

// BitScanForward.cpp
// compile with: /EHsc
#include <iostream>
#include <intrin.h>
using namespace std;

#pragma intrinsic(_BitScanForward)

int main()
{
   unsigned long mask = 0x1000;
   unsigned long index;
   unsigned char isNonzero;

   cout << "Enter a positive integer as the mask: " << flush;
   cin >> mask;
   isNonzero = _BitScanForward(&index, mask);
   if (isNonzero)
   {
      cout << "Mask: " << mask << " Index: " << index << endl;
   }
   else
   {
      cout << "No set bits found.  Mask is zero." << endl;
   }
}
12
Enter a positive integer as the mask:
Mask: 12 Index: 2

Microsoft 固有の仕様はここまで

関連項目

コンパイラの組み込み