Esta documentación está archivada y no tiene mantenimiento.

PerformanceCounterCategory.Exists (Método) (String)

Determina si la categoría está registrada en el equipo local.

Espacio de nombres: System.Diagnostics
Ensamblado: System (en system.dll)

public static bool Exists (
	string categoryName
)
public static boolean Exists (
	String categoryName
)
public static function Exists (
	categoryName : String
) : boolean

Parámetros

categoryName

Nombre de la categoría de contador de rendimiento que se va a buscar.

Valor devuelto

Es true si la categoría está registrada; de lo contrario, es false.

Tipo de excepciónCondición

ArgumentNullException

El valor del parámetro categoryName es referencia de objeto null (Nothing en Visual Basic).

ArgumentException

El parámetro categoryName es una cadena vacía ("").

Win32Exception

Se ha producido un error en la llamada a una API del sistema subyacente.

El uso del método Exists puede producir una reducción del rendimiento notable mientras se comprueba la disponibilidad de todos los contadores de rendimiento. Sí sólo está escribiendo a un contador de rendimiento, puede evitar la búsqueda global de contadores de rendimiento creando el contador de rendimiento cuando se instala la aplicación y considerando que la categoría existe cuando se obtiene acceso al contador. No hay ninguna manera de evitar la búsqueda del contador de rendimiento cuando se leen los contadores de rendimiento.

if(!PerformanceCounterCategory.Exists("Orders")) {          
    CounterCreationData milk = new CounterCreationData();
    milk.CounterName = "milk";
    milk.CounterType = PerformanceCounterType.NumberOfItems32;
    
    CounterCreationData milkPerSecond = new CounterCreationData();
    milkPerSecond.CounterName = "milk orders/second";
    milkPerSecond.CounterType = PerformanceCounterType.RateOfCountsPerSecond32;
   
    CounterCreationDataCollection ccds = new CounterCreationDataCollection();
    ccds.Add(milkPerSecond);
    ccds.Add(milk);
    
    PerformanceCounterCategory.Create("Orders","Number of processed orders",ccds);           
}

if (!PerformanceCounterCategory.Exists("Orders")) {
    CounterCreationData milk = new CounterCreationData();
    milk.set_CounterName("milk");
    milk.set_CounterType(PerformanceCounterType.NumberOfItems32);

    CounterCreationData milkPerSecond = new CounterCreationData();
    milkPerSecond.set_CounterName("milk orders/second");
    milkPerSecond.set_CounterType(PerformanceCounterType.
        RateOfCountsPerSecond32);
    CounterCreationDataCollection ccds = 
        new CounterCreationDataCollection();
    ccds.Add(milkPerSecond);
    ccds.Add(milk);

    PerformanceCounterCategory.Create("Orders",
        "Number of processed orders", ccds);
}

Windows 98, Windows 2000 SP4, Windows Server 2003, Windows XP Media Center, Windows XP Professional x64, Windows XP SP2, Windows XP Starter Edition

.NET Framework no admite todas las versiones de cada plataforma. Para obtener una lista de las versiones admitidas, vea Requisitos del sistema.

.NET Framework

Compatible con: 2.0, 1.1, 1.0
Mostrar: