_BitScanForward, _BitScanForward64
Microsoft 特定的
從遮罩資料的最低有效位元 (MSB) 到最高有效位元 (LSB) 搜尋設定位元 (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;否則為非零。
備註
如果找到設定位,則第一個設定位的位位置會寫入第一個參數中指定的位址,而函式會傳回 1。 如果找不到位,函式會傳回 0,且寫入至第一個參數中位址的值未定義。
需求
內建 | 架構 |
---|---|
_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
END Microsoft 特定的
另請參閱
意見反映
https://aka.ms/ContentUserFeedback。
即將推出:我們會在 2024 年淘汰 GitHub 問題,並以全新的意見反應系統取代並作為內容意見反應的渠道。 如需更多資訊,請參閱:提交及檢視以下的意見反映: