RtlNumberGenericTableElements routine

The RtlNumberGenericTableElements routine returns the number of elements in a generic table.

Syntax


ULONG RtlNumberGenericTableElements(
  _In_ PRTL_GENERIC_TABLE Table
);

Parameters

Table [in]

Pointer to the generic table (RTL_GENERIC_TABLE). The table must have been initialized by calling RtlInitializeGenericTable.

Return value

RtlNumberGenericTableElements returns the number of elements that are currently stored in the table.

Remarks

Callers of the Rtl..GenericTable routines are responsible for exclusively synchronizing access to the generic table. An exclusive fast mutex is the most efficient synchronization mechanism to use for this purpose.

By default, the operating system uses splay trees to implement generic tables. Under some circumstances, operations on a splay tree will make the tree deep and narrow and might even turn it into a straight line. Very deep trees degrade the performance of searches. You can ensure a more balanced, shallower tree implementation of generic tables by using Adelson-Velsky/Landis (AVL) trees. If you want to configure the generic table routines to use AVL trees instead of splay trees in your driver, insert the following define statement in a common header file before including Ntddk.h:

#define RTL_USE_AVL_TABLES 0

If RTL_USE_AVL_TABLES is not defined, you must use the AVL form of the generic table routines. For example, use the RtlNumberGenericTableElementsAvl routine instead of RtlNumberGenericTableElements. In the call to RtlNumberGenericTableElementsAvl, the caller must pass a RTL_AVL_TABLE table structure rather than RTL_GENERIC_TABLE.

Callers of RtlNumberGenericTableElements must be running at IRQL < DISPATCH_LEVEL if the caller-allocated memory for the generic table is pageable.

Requirements

Target platform

Universal

Header

Ntddk.h (include Ntddk.h or Ntifs.h)

Library

NtosKrnl.lib

DLL

NtosKrnl.exe

IRQL

< DISPATCH_LEVEL (see Remarks section)

See also

RtlInitializeGenericTable
RtlIsGenericTableEmpty

 

 

Send comments about this topic to Microsoft

Show: