Función PdhExpandCounterPathA (pdh.h)
Examina el equipo especificado (o equipo local si no se especifica ninguno) para contadores e instancias de contadores que coinciden con las cadenas con caracteres comodín en la ruta de acceso del contador.
Sintaxis
PDH_FUNCTION PdhExpandCounterPathA(
[in] LPCSTR szWildCardPath,
[out] PZZSTR mszExpandedPathList,
[in, out] LPDWORD pcchPathListLength
);
Parámetros
[in] szWildCardPath
cadena terminada en nullque contiene la ruta de acceso del contador que se va a expandir. La función busca coincidencias en el equipo especificado en la ruta de acceso. Si la ruta de acceso no especifica un equipo, la función busca en el equipo local. La longitud máxima de una ruta de acceso de contador es PDH_MAX_COUNTER_PATH.
[out] mszExpandedPathList
Búfer asignado por el autor de la llamada que recibe la lista de rutas de acceso de contador expandidas que coinciden con la especificación de caracteres comodín en szWildCardPath. Cada ruta de acceso de contador de esta lista finaliza mediante un carácter null. La lista finaliza con dos caracteres NULL. Establézcalo en NULL si pcchPathListLength es cero.
[in, out] pcchPathListLength
Tamaño del búfer de mszExpandedPathList de
Valor devuelto
Si la función se ejecuta correctamente, devuelve ERROR_SUCCESS.
Si se produce un error en la función, el valor devuelto es un código de error del sistema o un código de error PDH .
Código devuelto | Descripción |
---|---|
|
El mszExpandedPathList búfer es demasiado pequeño para contener la lista de rutas de acceso. Este valor devuelto se espera si pcchPathListLength es cero en la entrada. Si el tamaño especificado en la entrada es mayor que cero pero menor que el tamaño necesario, no debe confiar en el tamaño devuelto para reasignar el búfer. |
|
Un parámetro no es válido. Por ejemplo, en algunas versiones podría recibir este error si el tamaño especificado en la entrada es mayor que cero pero menor que el tamaño necesario. |
|
No se puede asignar memoria para admitir esta función. |
Observaciones
Debe llamar a esta función dos veces, la primera vez que obtenga el tamaño de búfer necesario (establezca mszExpandedPathList en NULL y pcchPathListLength en 0) y la segunda vez para obtener los datos.
El formato de ruta de acceso de contador general es el siguiente:
\computer\object(parent/instance#index)\counter
Los componentes primarios, de instancia, índice y contador de la ruta de acceso del contador pueden contener un nombre válido o un carácter comodín. Los componentes de equipo, primario, instancia e índice no son necesarios para todos los contadores.
Las rutas de acceso de contador que debe usar están determinadas por el propio contador. Por ejemplo, el objeto LogicalDisk tiene un índice de instancia, por lo que debe proporcionar el #index o un carácter comodín. Por lo tanto, puede usar el formato siguiente:
\LogicalDisk(/#*)*
En comparación, el objeto Process no requiere un índice de instancia. Por lo tanto, puede usar el formato siguiente:
\Process(*)\ID Process
A continuación se muestra una lista de los posibles formatos:
- \\computer\object(parent/instance#index)\counter
- \\computer\object(parent/instance)\counter
- \\computer\object(instance#index)\counter
- \\computer\object(instance)\counter
- \\computer\object\counter
- \object(parent/instance#index)\counter
- \object(parent/instance)\counter
- \object(instance#index)\counter
- \object(instance)\counter
- \object\counter
Si se especifica un carácter comodín en el nombre de instancia, se devolverán todas las instancias del objeto y el objeto primario especificados si todos los nombres de instancia correspondientes al índice especificado coinciden con el carácter comodín.
Si se especifica un carácter comodín en el nombre del contador, se devuelven todos los contadores del objeto especificado.
No se admiten coincidencias de cadena de ruta de acceso de contador parcial (por ejemplo, "pro*").
Ejemplos
En el ejemplo siguiente se muestra cómo realizar esta función.
#include <windows.h>
#include <stdio.h>
#include <stdlib.h>
#include <pdh.h>
#include <pdhmsg.h>
#pragma comment(lib, "pdh.lib")
CONST PWSTR WILDCARD_PATH = L"\\Processor(*)\\*";
void wmain(void)
{
PDH_STATUS Status;
PWSTR EndOfPaths;
PWSTR Paths = NULL;
DWORD BufferSize = 0;
Status = PdhExpandCounterPath(WILDCARD_PATH, Paths, &BufferSize);
while (Status == PDH_MORE_DATA)
{
Paths = (PWSTR)malloc(BufferSize * sizeof(WCHAR));
Status = PdhExpandCounterPath(WILDCARD_PATH, Paths, &BufferSize);
}
if (Status != ERROR_SUCCESS)
{
wprintf(L"\nPdhExpandCounterPath failed with status 0x%x", Status);
goto Cleanup;
}
if (Paths == NULL)
{
wprintf(L"\nThe counter path %s cannot be expanded.", WILDCARD_PATH);
goto Cleanup;
}
EndOfPaths = Paths + BufferSize;
// On Vista and later operating systems, the buffer is terminated with two
// null-terminator characters; however, on earlier systems, the buffer is
// not terminated with two null-terminator characters. This covers both cases.
for (PWSTR p = Paths; ((p != EndOfPaths) && (*p != L'\0')); p += wcslen(p) + 1)
{
wprintf(L"\n%s", p);
}
Cleanup:
if (Paths)
{
free(Paths);
}
}
Nota
El encabezado pdh.h define PdhExpandCounterPath como alias que selecciona automáticamente la versión ANSI o Unicode de esta función en función de la definición de la constante de preprocesador UNICODE. La combinación del uso del alias neutral de codificación con código que no es neutral de codificación puede dar lugar a errores de coincidencia que dan lugar a errores de compilación o tiempo de ejecución. Para obtener más información, vea Conventions for Function Prototypes.
Requisitos
Requisito | Valor |
---|---|
cliente mínimo admitido | Windows XP [solo aplicaciones de escritorio] |
servidor mínimo admitido | Windows Server 2003 [solo aplicaciones de escritorio] |
de la plataforma de destino de |
Windows |
encabezado de |
pdh.h |
biblioteca de |
Pdh.lib |
DLL de |
Pdh.dll |