_BitScanForward, _BitScanForward64
Specyficzne dla firmy Microsoft
Wyszukiwanie danych maska z co najmniej znaczących bit (Znaczącym) na najbardziej znaczących bitów (NZB) dla zestawu bit (1).
unsigned char _BitScanForward( unsigned long * Index, unsigned long Mask ); unsigned char _BitScanForward64( unsigned long * Index, unsigned __int64 Mask );
Parametry
[limit]Index
Załadowana pozycji bitu pierwszego ustawiony bit (1) znaleźć.[w]Mask
32-bitowy lub 64-bitowej wartości do wyszukania.
Wartość zwracana
0, jeśli maska wynosi zero; różna od zera, w przeciwnym razie.
Uwagi
W przypadku znalezienia bit zestawu w pierwszym parametrze jest zwracana pozycja bitowe pierwszy bit zestaw znaleziono.Przypadku nieznalezienia nie bitowy zestaw, zwracana jest 0; w przeciwnym razie zwracany jest 1.
Wymagania
Wewnętrzne |
Architektura |
---|---|
_BitScanForward |
x 86, ARM,x64 |
_BitScanForward64 |
ARM,x64 |
Plik nagłówka < intrin.h >
Przykład
// 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;
}
}
Dane wejściowe
12
Przykładowe dane wyjściowe
Enter a positive integer as the mask:
Mask: 12 Index: 2