Función RtlDeleteElementGenericTableAvl (ntddk.h)

La rutina RtlDeleteElementGenericTableAvl elimina un elemento de una tabla genérica.

Sintaxis

NTSYSAPI BOOLEAN RtlDeleteElementGenericTableAvl(
  [in] PRTL_AVL_TABLE Table,
  [in] PVOID          Buffer
);

Parámetros

[in] Table

Puntero a la tabla genérica (RTL_AVL_TABLE). La tabla debe haberse inicializado llamando a RtlInitializeGenericTableAvl.

[in] Buffer

Puntero a un búfer asignado por el autor de la llamada que contiene un valor que identifica de forma única el elemento que se va a eliminar.

Valor devuelto

RtlDeleteElementGenericTableAvl devuelve TRUE si el elemento se eliminó correctamente; en caso contrario, FALSE .

Comentarios

RtlDeleteElementGenericTableAvl llama a CompareRoutine y FreeRoutine registrados en la llamada a RtlInitializeGenericTableAvl.

De forma predeterminada, el sistema operativo usa árboles de reproducción para implementar tablas genéricas, pero la rutina RtlDeleteElementGenericTableAvl solo funciona con árboles Adelson-Velsky/Landis (AVL). Para configurar las rutinas de tabla genéricas para usar árboles AVL en lugar de árboles de reproducción en el controlador, inserte la siguiente instrucción define en un archivo de encabezado común antes de incluir Ntddk.h:

#define RTL_USE_AVL_TABLES 0

Si no se define RTL_USE_AVL_TABLES, debe usar el formato AVL de las rutinas de tabla genéricas. Por ejemplo, use la rutina RtlDeleteElementGenericTableAvl en lugar de RtlDeleteElementGenericTable. En la llamada a RtlDeleteElementGenericTableAvl, el autor de la llamada debe pasar una estructura de tabla de RTL_AVL_TABLE en lugar de RTL_GENERIC_TABLE.

Autores de llamadas de Rtl.. Las rutinas GenericTableAvl son responsables de sincronizar exclusivamente el acceso a la tabla genérica. Una exclusión mutua rápida exclusiva es el mecanismo de sincronización más eficaz que se usará para este propósito.

Los autores de llamadas de RtlDeleteElementGenericTableAvl deben ejecutarse en IRQL < DISPATCH_LEVEL si alguna de las condiciones siguientes contiene:

  • La memoria asignada por el autor de la llamada en Table o at Buffer es paginable.
  • CompareRoutine o FreeRoutine proporcionado por el autor de la llamada contiene código paginable.

Requisitos

Requisito Value
Cliente mínimo compatible Disponible a partir de Windows XP.
Plataforma de destino Universal
Encabezado ntddk.h (incluya Ntddk.h, Ntifs.h)
Library NtosKrnl.lib
Archivo DLL NtosKrnl.exe
IRQL vea la sección Comentarios.

Consulte también

RtlInitializeGenericTableAvl

RtlInsertElementGenericTableAvl