RtlFindSetBitsAndClear 函数 (wdm.h)
RtlFindSetBitsAndClear 例程在位图中搜索请求大小的集位范围,并在找到该范围时清除该范围中的所有位。
语法
NTSYSAPI ULONG RtlFindSetBitsAndClear(
[in] PRTL_BITMAP BitMapHeader,
[in] ULONG NumberToFind,
[in] ULONG HintIndex
);
参数
[in] BitMapHeader
指向描述位图 的RTL_BITMAP 结构的指针。 此结构必须已由 RtlInitializeBitMap 例程初始化。
[in] NumberToFind
指定满足此请求的连续集位数。
[in] HintIndex
指定从零开始的位位置,以便开始查找给定大小的设置位范围。
返回值
RtlFindSetBitsAndClear 返回它清除的请求大小的设置位范围的从零开始的起始位索引,或者如果它在给定位图变量中找不到此类范围,则返回0xFFFFFFFF。
注解
对于成功的调用,返回的位位置不一定等效于给定的 HintIndex。 如有必要, RtlFindSetBitsAndClear 搜索整个位图以查找所请求大小的设置位范围。 但是,它会在 HintIndex 附近开始搜索请求的范围,因此当调用方可以提供有关开始查找位置的适当提示时,可以更快地清除此类范围。
如果包含位图变量的内存可分页或 BitMapHeader 上的内存可分页,则 RtlFindSetBitsAndClear 的调用方必须在 IRQL <= APC_LEVEL 运行。 否则,可以在任何 IRQL 中调用 RtlFindSetBitsAndClear 。
要求
要求 | 值 |
---|---|
最低受支持的客户端 | 从 Windows 2000 开始可用。 |
目标平台 | 通用 |
标头 | wdm.h(包括 Wdm.h、Ntddk.h、Ntifs.h) |
Library | NtosKrnl.lib |
DLL | NtosKrnl.exe |
IRQL | <= APC_LEVEL (请参阅备注部分) |