다음을 통해 공유


_BitScanForward, _BitScanForward64

Microsoft 전용

LSB(최하위 비트)에서 MSB(최상위 비트)로의 마스크 데이터에서 설정 비트(1)를 검색합니다.

구문

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

매개 변수

Index
[out] 찾은 첫 번째 집합 비트(1)의 비트 위치와 함께 로드됩니다.

마스크
[in] 검색할 32비트 또는 64비트 값입니다.

반환 값

마스크가 0이면 0이고 그렇지 않으면 0이 아닙니다.

설명

설정된 비트가 있으면 첫 번째 집합 비트의 비트 위치가 첫 번째 매개 변수에 지정된 주소에 기록되고 함수는 1을 반환합니다. 비트가 없으면 함수는 0을 반환하고 첫 번째 매개 변수의 주소에 기록된 값은 정의되지 않습니다.

요구 사항

Intrinsic 아키텍처
_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 전용 종료

참고 항목

컴파일러 내장 함수