RtlNumberGenericTableElementsAvl 函数 (ntddk.h)

RtlNumberGenericTableElementsAvl 例程返回泛型表中的元素数。

语法

NTSYSAPI ULONG RtlNumberGenericTableElementsAvl(
  [in] PRTL_AVL_TABLE Table
);

参数

[in] Table

指向泛型表 (RTL_AVL_TABLE) 的指针。 表必须已通过调用 RtlInitializeGenericTableAvl 进行初始化。

返回值

RtlNumberGenericTableElementsAvl 返回表中当前存储的元素数。

注解

默认情况下,操作系统使用 splay 树来实现泛型表,但 RtlNumberGenericTableElementsAvl 例程仅适用于 Adelson-Velsky/Landis (AVL) 树。 若要将泛型表例程配置为在驱动程序中使用 AVL 树而不是 splay 树,请在包含 Ntddk.h 之前在通用头文件中插入以下 define 语句:

#define RTL_USE_AVL_TABLES 0

如果未定义RTL_USE_AVL_TABLES,则必须使用泛型表例程的 AVL 形式。 例如,使用 RtlNumberGenericTableElementsAvl 例程,而不是 RtlNumberGenericTableElements。 在调用 RtlNumberGenericTableElementsAvl 时,调用方必须传递 RTL_AVL_TABLE 表结构,而不是 RTL_GENERIC_TABLE

Rtl. 的调用方。GenericTableAvl 例程负责以独占方式同步对泛型表的访问。 排他快速互斥体是用于此目的的最有效同步机制。

如果泛型表的调用方分配的内存可分页,则 RtlNumberGenericTableElementsAvl 的调用方必须在 IRQL < DISPATCH_LEVEL运行。

要求

要求
最低受支持的客户端 从 Windows XP 开始可用。
目标平台 通用
标头 ntddk.h (包括 Ntddk.h、Ntifs.h)
Library NtosKrnl.lib
DLL NtosKrnl.exe
IRQL < DISPATCH_LEVEL (请参阅“备注”部分)

另请参阅

RtlInitializeGenericTableAvl

RtlIsGenericTableEmptyAvl