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 (请参阅备注部分)

另请参阅

RTL_BITMAP

RtlAreBitsSet

RtlClearAllBits

RtlClearBits

RtlFindSetBits

RtlInitializeBitMap

RtlNumberOfSetBits