InstanceDataCollectionCollection Klasa
Definicja
Ważne
Niektóre informacje odnoszą się do produktu w wersji wstępnej, który może zostać znacząco zmodyfikowany przed wydaniem. Firma Microsoft nie udziela żadnych gwarancji, jawnych lub domniemanych, w odniesieniu do informacji podanych w tym miejscu.
Zawiera silnie typizowana kolekcja InstanceDataCollection obiektów.
public ref class InstanceDataCollectionCollection : System::Collections::DictionaryBase
public class InstanceDataCollectionCollection : System.Collections.DictionaryBase
type InstanceDataCollectionCollection = class
inherit DictionaryBase
Public Class InstanceDataCollectionCollection
Inherits DictionaryBase
- Dziedziczenie
Przykłady
W poniższym przykładzie kodu są wyświetlane dane wystąpienia określonego PerformanceCounterCategory na komputerze lokalnym. Najpierw wyświetla listę PerformanceCounterCategory numerowanych nazw. Gdy użytkownik wprowadzi liczbę jednej z kategorii, przykład pobierze InstanceDataCollectionCollection wartość dla tego PerformanceCounterCategoryelementu . Następnie konwertuje kolekcję zwróconą Values przez właściwość na tablicę InstanceDataCollection obiektów. W przykładzie są wyświetlane dane wystąpienia skojarzone z każdym InstanceData z nich InstanceDataCollection.
using System;
using System.Diagnostics;
using System.Collections;
class InstDataKeysValuesMod
{
private static string categoryName;
public static void Main()
{
string catNumStr;
int categoryNum;
PerformanceCounterCategory[] categories = PerformanceCounterCategory.GetCategories();
Console.WriteLine("These categories are registered on this computer:");
int catX;
for(catX=0; catX<categories.Length; catX++)
{
Console.WriteLine("{0,4} - {1}", catX+1, categories[catX].CategoryName);
}
// Ask the user to choose a category.
Console.Write("Enter the category number from the above list: ");
catNumStr = Console.ReadLine();
// Validate the entered category number.
try
{
categoryNum = int.Parse(catNumStr);
if (categoryNum<1||categoryNum>categories.Length)
{
throw new Exception(String.Format("The category number must be in the " +
"range 1..{0}.", categories.Length));
}
categoryName = categories[(categoryNum - 1)].CategoryName;
}
catch(Exception ex)
{
Console.WriteLine("\"{0}\" is not a valid category number." +
"\r\n{1}", catNumStr, ex.Message);
return;
}
// Process the InstanceDataCollectionCollection for this category.
PerformanceCounterCategory pcc = new PerformanceCounterCategory(categoryName);
InstanceDataCollectionCollection idColCol = pcc.ReadCategory();
ICollection idColColKeys = idColCol.Keys;
string[] idCCKeysArray = new string[idColColKeys.Count];
idColColKeys.CopyTo(idCCKeysArray, 0);
ICollection idColColValues = idColCol.Values;
InstanceDataCollection[] idCCValuesArray = new InstanceDataCollection[idColColValues.Count];
idColColValues.CopyTo(idCCValuesArray, 0);
Console.WriteLine("InstanceDataCollectionCollection for \"{0}\" " +
"has {1} elements.", categoryName, idColCol.Count);
// Display the InstanceDataCollectionCollection Keys and Values.
// The Keys and Values collections have the same number of elements.
int index;
for(index=0; index<idCCKeysArray.Length; index++)
{
Console.WriteLine(" Next InstanceDataCollectionCollection " +
"Key is \"{0}\"", idCCKeysArray[index]);
ProcessInstanceDataCollection(idCCValuesArray[index]);
}
}
// Display the contents of an InstanceDataCollection.
public static void ProcessInstanceDataCollection(InstanceDataCollection idCol)
{
ICollection idColKeys = idCol.Keys;
string[] idColKeysArray = new string[idColKeys.Count];
idColKeys.CopyTo(idColKeysArray, 0);
ICollection idColValues = idCol.Values;
InstanceData[] idColValuesArray = new InstanceData[idColValues.Count];
idColValues.CopyTo(idColValuesArray, 0);
Console.WriteLine(" InstanceDataCollection for \"{0}\" " +
"has {1} elements.", idCol.CounterName, idCol.Count);
// Display the InstanceDataCollection Keys and Values.
// The Keys and Values collections have the same number of elements.
int index;
for(index=0; index<idColKeysArray.Length; index++)
{
Console.WriteLine(" Next InstanceDataCollection " +
"Key is \"{0}\"", idColKeysArray[index]);
ProcessInstanceDataObject(idColValuesArray[index]);
}
}
// Display the contents of an InstanceData object.
public static void ProcessInstanceDataObject(InstanceData instData)
{
CounterSample sample = instData.Sample;
Console.WriteLine(" From InstanceData:\r\n " +
"InstanceName: {0,-31} RawValue: {1}", instData.InstanceName, instData.Sample.RawValue);
Console.WriteLine(" From CounterSample:\r\n " +
"CounterType: {0,-32} SystemFrequency: {1}\r\n" +
" BaseValue: {2,-34} RawValue: {3}\r\n" +
" CounterFrequency: {4,-27} CounterTimeStamp: {5}\r\n" +
" TimeStamp: {6,-34} TimeStamp100nSec: {7}", sample.CounterType, sample.SystemFrequency, sample.BaseValue, sample.RawValue, sample.CounterFrequency, sample.CounterTimeStamp, sample.TimeStamp, sample.TimeStamp100nSec);
}
}
Imports System.Diagnostics
Imports System.Collections
Module InstDataKeysValuesMod
Private categoryName As String
Sub Main()
Dim catNumStr As String
Dim categoryNum As Integer
Dim categories As PerformanceCounterCategory() = _
PerformanceCounterCategory.GetCategories()
Console.WriteLine( _
"These categories are registered on this computer:")
Dim catX As Integer
For catX = 0 To categories.Length - 1
Console.WriteLine("{0,4} - {1}", catX + 1, _
categories(catX).CategoryName)
Next catX
' Ask the user to choose a category.
Console.Write( _
"Enter the category number from the above list: ")
catNumStr = Console.ReadLine()
' Validate the entered category number.
Try
categoryNum = Integer.Parse(catNumStr)
If categoryNum < 1 Or categoryNum > categories.Length Then
Throw New Exception( _
String.Format("The category number must be in the " & _
"range 1..{0}.", categories.Length))
End If
categoryName = categories((categoryNum - 1)).CategoryName
Catch ex As Exception
Console.WriteLine("""{0}"" is not a valid category number." & _
vbCrLf & "{1}", catNumStr, ex.Message)
Return
End Try
' Process the InstanceDataCollectionCollection for this category.
Dim pcc As New PerformanceCounterCategory(categoryName)
Dim idColCol As InstanceDataCollectionCollection = pcc.ReadCategory()
Dim idColColKeys As ICollection = idColCol.Keys
Dim idCCKeysArray(idColColKeys.Count - 1) As String
idColColKeys.CopyTo(idCCKeysArray, 0)
Dim idColColValues As ICollection = idColCol.Values
Dim idCCValuesArray(idColColValues.Count - 1) As InstanceDataCollection
idColColValues.CopyTo(idCCValuesArray, 0)
Console.WriteLine("InstanceDataCollectionCollection for ""{0}"" " & _
"has {1} elements.", categoryName, idColCol.Count)
' Display the InstanceDataCollectionCollection Keys and Values.
' The Keys and Values collections have the same number of elements.
Dim index As Integer
For index = 0 To idCCKeysArray.Length - 1
Console.WriteLine(" Next InstanceDataCollectionCollection " & _
"Key is ""{0}""", idCCKeysArray(index))
ProcessInstanceDataCollection(idCCValuesArray(index))
Next index
End Sub
' Display the contents of an InstanceDataCollection.
Sub ProcessInstanceDataCollection(ByVal idCol As InstanceDataCollection)
Dim idColKeys As ICollection = idCol.Keys
Dim idColKeysArray(idColKeys.Count - 1) As String
idColKeys.CopyTo(idColKeysArray, 0)
Dim idColValues As ICollection = idCol.Values
Dim idColValuesArray(idColValues.Count - 1) As InstanceData
idColValues.CopyTo(idColValuesArray, 0)
Console.WriteLine(" InstanceDataCollection for ""{0}"" " & _
"has {1} elements.", idCol.CounterName, idCol.Count)
' Display the InstanceDataCollection Keys and Values.
' The Keys and Values collections have the same number of elements.
Dim index As Integer
For index = 0 To idColKeysArray.Length - 1
Console.WriteLine(" Next InstanceDataCollection " & _
"Key is ""{0}""", idColKeysArray(index))
ProcessInstanceDataObject(idColValuesArray(index))
Next index
End Sub
' Display the contents of an InstanceData object.
Sub ProcessInstanceDataObject(ByVal instData As InstanceData)
Dim sample As CounterSample = instData.Sample
Console.WriteLine(" From InstanceData:" & vbCrLf & " " & _
"InstanceName: {0,-31} RawValue: {1}", _
instData.InstanceName, instData.Sample.RawValue)
Console.WriteLine(" From CounterSample:" & vbCrLf & " " & _
"CounterType: {0,-32} SystemFrequency: {1}" & vbCrLf & _
" BaseValue: {2,-34} RawValue: {3}" & vbCrLf & _
" CounterFrequency: {4,-27} CounterTimeStamp: {5}" & vbCrLf & _
" TimeStamp: {6,-34} TimeStamp100nSec: {7}", _
sample.CounterType, sample.SystemFrequency, sample.BaseValue, _
sample.RawValue, sample.CounterFrequency, sample.CounterTimeStamp, _
sample.TimeStamp, sample.TimeStamp100nSec)
End Sub
End Module
Uwagi
Klasa InstanceDataCollectionCollection reprezentuje kolekcję zwróconą ReadCategory z metody . Ta kolekcja zawiera wszystkie dane licznika i wystąpienia. Kolekcja zawiera InstanceDataCollection obiekt dla każdego licznika. Każdy InstanceDataCollection obiekt zawiera dane wydajności dla wszystkich liczników dla tego wystąpienia. W związku z tym dane są indeksowane według nazwy licznika, a następnie według nazwy wystąpienia.
Konstruktory
InstanceDataCollectionCollection() |
Przestarzałe.
Przestarzałe.
Przestarzałe.
Inicjuje nowe wystąpienie klasy InstanceDataCollectionCollection. |
Właściwości
Count |
Pobiera liczbę elementów zawartych w wystąpieniu DictionaryBase . (Odziedziczone po DictionaryBase) |
Dictionary |
Pobiera listę elementów zawartych w wystąpieniu DictionaryBase . (Odziedziczone po DictionaryBase) |
InnerHashtable |
Pobiera listę elementów zawartych w wystąpieniu DictionaryBase . (Odziedziczone po DictionaryBase) |
Item[String] |
Pobiera dane wystąpienia dla określonego licznika. |
Keys |
Pobiera klucze rejestru obiektów i liczników dla obiektów skojarzonych z tym wystąpieniem zbierania danych. |
Values |
Pobiera wartości danych wystąpienia, które składają się na kolekcję wystąpień dla licznika. |
Metody
Clear() |
Czyści zawartość DictionaryBase wystąpienia. (Odziedziczone po DictionaryBase) |
Contains(String) |
Określa, czy w kolekcji istnieje zbieranie danych wystąpienia dla określonego licznika (określonego przez jeden z indeksowanych InstanceDataCollection obiektów). |
CopyTo(Array, Int32) |
Kopiuje DictionaryBase elementy do jednowymiarowego Array w określonym indeksie. (Odziedziczone po DictionaryBase) |
CopyTo(InstanceDataCollection[], Int32) |
Kopiuje tablicę InstanceDataCollection wystąpień do kolekcji w określonym indeksie. |
Equals(Object) |
Określa, czy dany obiekt jest taki sam, jak bieżący obiekt. (Odziedziczone po Object) |
GetEnumerator() |
Zwraca obiekt, który IDictionaryEnumerator iteruje po wystąpieniu DictionaryBase . (Odziedziczone po DictionaryBase) |
GetHashCode() |
Służy jako domyślna funkcja skrótu. (Odziedziczone po Object) |
GetType() |
Type Pobiera wartość bieżącego wystąpienia. (Odziedziczone po Object) |
MemberwiseClone() |
Tworzy płytkią kopię bieżącego Objectelementu . (Odziedziczone po Object) |
OnClear() |
Wykonuje dodatkowe procesy niestandardowe przed wyczyszczeniem zawartości DictionaryBase wystąpienia. (Odziedziczone po DictionaryBase) |
OnClearComplete() |
Wykonuje dodatkowe procesy niestandardowe po wyczyszczeniu zawartości DictionaryBase wystąpienia. (Odziedziczone po DictionaryBase) |
OnGet(Object, Object) |
Pobiera element z określonym kluczem i wartością w wystąpieniu DictionaryBase . (Odziedziczone po DictionaryBase) |
OnInsert(Object, Object) |
Wykonuje dodatkowe procesy niestandardowe przed wstawieniem nowego elementu do DictionaryBase wystąpienia. (Odziedziczone po DictionaryBase) |
OnInsertComplete(Object, Object) |
Wykonuje dodatkowe procesy niestandardowe po wstawieniu nowego elementu do DictionaryBase wystąpienia. (Odziedziczone po DictionaryBase) |
OnRemove(Object, Object) |
Wykonuje dodatkowe procesy niestandardowe przed usunięciem elementu z DictionaryBase wystąpienia. (Odziedziczone po DictionaryBase) |
OnRemoveComplete(Object, Object) |
Wykonuje dodatkowe procesy niestandardowe po usunięciu DictionaryBase elementu z wystąpienia. (Odziedziczone po DictionaryBase) |
OnSet(Object, Object, Object) |
Wykonuje dodatkowe procesy niestandardowe przed ustawieniem wartości w wystąpieniu DictionaryBase . (Odziedziczone po DictionaryBase) |
OnSetComplete(Object, Object, Object) |
Wykonuje dodatkowe procesy niestandardowe po ustawieniu wartości w wystąpieniu DictionaryBase . (Odziedziczone po DictionaryBase) |
OnValidate(Object, Object) |
Wykonuje dodatkowe procesy niestandardowe podczas sprawdzania poprawności elementu przy użyciu określonego klucza i wartości. (Odziedziczone po DictionaryBase) |
ToString() |
Zwraca ciąg reprezentujący bieżący obiekt. (Odziedziczone po Object) |
Jawne implementacje interfejsu
ICollection.IsSynchronized |
Pobiera wartość wskazującą DictionaryBase , czy dostęp do obiektu jest synchronizowany (bezpieczny wątek). (Odziedziczone po DictionaryBase) |
ICollection.SyncRoot |
Pobiera obiekt, który może służyć do synchronizowania dostępu do DictionaryBase obiektu. (Odziedziczone po DictionaryBase) |
IDictionary.Add(Object, Object) |
Dodaje element z określonym kluczem i wartością do elementu DictionaryBase. (Odziedziczone po DictionaryBase) |
IDictionary.Contains(Object) |
Określa, czy element DictionaryBase zawiera określony klucz. (Odziedziczone po DictionaryBase) |
IDictionary.IsFixedSize |
Pobiera wartość wskazującą DictionaryBase , czy obiekt ma stały rozmiar. (Odziedziczone po DictionaryBase) |
IDictionary.IsReadOnly |
Pobiera wartość wskazującą DictionaryBase , czy obiekt jest tylko do odczytu. (Odziedziczone po DictionaryBase) |
IDictionary.Item[Object] |
Pobiera lub ustawia wartość skojarzona z określonym kluczem. (Odziedziczone po DictionaryBase) |
IDictionary.Keys |
ICollection Pobiera obiekt zawierający klucze w DictionaryBase obiekcie . (Odziedziczone po DictionaryBase) |
IDictionary.Remove(Object) |
Usuwa element z określonym kluczem z .DictionaryBase (Odziedziczone po DictionaryBase) |
IDictionary.Values |
ICollection Pobiera obiekt zawierający wartości w DictionaryBase obiekcie. (Odziedziczone po DictionaryBase) |
IEnumerable.GetEnumerator() |
Zwraca wartość IEnumerator , która iteruje za pośrednictwem elementu DictionaryBase. (Odziedziczone po DictionaryBase) |
Metody rozszerzania
Cast<TResult>(IEnumerable) |
Rzutuje elementy obiektu IEnumerable na określony typ. |
OfType<TResult>(IEnumerable) |
Filtruje elementy IEnumerable elementu na podstawie określonego typu. |
AsParallel(IEnumerable) |
Umożliwia równoległość zapytania. |
AsQueryable(IEnumerable) |
Konwertuje element IEnumerable na .IQueryable |