RtlIsGenericTableEmpty 函数 (ntddk.h)
RtlIsGenericTableEmpty 例程确定泛型表是否为空。
语法
NTSYSAPI BOOLEAN RtlIsGenericTableEmpty(
[in] PRTL_GENERIC_TABLE Table
);
参数
[in] Table
指向泛型表 (RTL_GENERIC_TABLE) 的指针。 表必须已通过调用 RtlInitializeGenericTable 进行初始化。
返回值
如果表包含一个或多个元素,则 RtlIsGenericTableEmpty 返回 FALSE,否则返回 TRUE。
注解
默认情况下,操作系统使用 splay 树来实现泛型表。 在某些情况下,对 splay 树的操作会使树变得深而窄,甚至可能将其变成直线。 非常深的树会降低搜索的性能。 可以通过使用 Adelson-Velsky/Landis (AVL) 树来确保泛型表的更平衡、更浅的树实现。 如果要将泛型表例程配置为使用驱动程序中的 AVL 树而不是 splay 树,请在包含 Ntddk.h 之前在通用头文件中插入以下 define 语句:
#define RTL_USE_AVL_TABLES 0
如果未定义RTL_USE_AVL_TABLES,则必须使用泛型表例程的 AVL 形式。 例如,使用 RtlIsGenericTableEmptyAvl 结构例程,而不是 RtlIsGenericTableEmpty。 在调用 RtlIsGenericTableEmptyAvl 时,调用方必须传递 RTL_AVL_TABLE 表结构,而不是 RTL_GENERIC_TABLE。
如果调用方在 Table 上分配的内存可分页,则 RtlIsGenericTableEmpty 的调用方必须在 ≤ APC_LEVEL 运行。
要求
要求 | 值 |
---|---|
最低受支持的客户端 | 此例程在 Microsoft Windows 2000 及更高版本上可用。 |
目标平台 | 通用 |
标头 | ntddk.h (包括 Ntddk.h、Ntifs.h) |
Library | NtosKrnl.lib |
DLL | NtosKrnl.exe |
IRQL | <= APC_LEVEL (请参阅备注部分) |