FileRecordSequence.ReadLogRecords Metoda
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.
Zwraca wyliczalną kolekcję rekordów w sekwencji. Nie można dziedziczyć tej metody.
public:
virtual System::Collections::Generic::IEnumerable<System::IO::Log::LogRecord ^> ^ ReadLogRecords(System::IO::Log::SequenceNumber start, System::IO::Log::LogRecordEnumeratorType logRecordEnum);
public System.Collections.Generic.IEnumerable<System.IO.Log.LogRecord> ReadLogRecords (System.IO.Log.SequenceNumber start, System.IO.Log.LogRecordEnumeratorType logRecordEnum);
abstract member ReadLogRecords : System.IO.Log.SequenceNumber * System.IO.Log.LogRecordEnumeratorType -> seq<System.IO.Log.LogRecord>
override this.ReadLogRecords : System.IO.Log.SequenceNumber * System.IO.Log.LogRecordEnumeratorType -> seq<System.IO.Log.LogRecord>
Public Function ReadLogRecords (start As SequenceNumber, logRecordEnum As LogRecordEnumeratorType) As IEnumerable(Of LogRecord)
Parametry
- start
- SequenceNumber
Numer sekwencji pierwszego rekordu, w którym rozpoczyna się odczyt.
- logRecordEnum
- LogRecordEnumeratorType
Prawidłowa LogRecordEnumeratorType wartość określająca sposób (czyli do przodu lub do tyłu), w którym rekordy powinny być odczytywane z elementu LogRecordSequence.
Zwraca
Wyliczenie kolekcji rekordów w sekwencji.
Implementuje
Wyjątki
Jeden lub więcej argumentów jest poza zakresem.
Nie można wykonać operacji, ponieważ sekwencja rekordów została otwarta z dostępem tylko do zapisu.
Sekwencja rekordów jest uszkodzona.
-lub-
Rekord został napisany z niezgodną wersją sekwencji rekordów.
Wyliczenie zostało zakończone.
-lub-
Wyliczenie nie zostało uruchomione. Należy wykonać wywołanie MoveNext() .
Metoda została wywołana po usunięciu sekwencji.
Za mało pamięci, aby kontynuować wykonywanie programu.
Przykłady
W poniższym przykładzie pokazano, jak za pomocą tej metody odczytywać rekordy w sekwencji dzienników.
// Read the records added to the log.
public void ReadRecords()
{
Encoding enc = Encoding.Unicode;
Console.WriteLine();
Console.WriteLine("Reading Log Records...");
try
{
foreach (LogRecord record in this.sequence.ReadLogRecords(this.sequence.BaseSequenceNumber, LogRecordEnumeratorType.Next))
{
byte[] data = new byte[record.Data.Length];
record.Data.Read(data, 0, (int)record.Data.Length);
string mystr = enc.GetString(data);
Console.WriteLine(" {0}", mystr);
}
}
catch (Exception e)
{
Console.WriteLine("Exception {0} {1}", e.GetType(), e.Message);
}
Console.WriteLine();
}
' Read the records added to the log.
Public Sub ReadRecords()
Dim enc As Encoding = Encoding.Unicode
Console.WriteLine()
Console.WriteLine("Reading Log Records...")
Try
For Each record In Me.sequence.ReadLogRecords(Me.sequence.BaseSequenceNumber, LogRecordEnumeratorType.Next)
Dim data(record.Data.Length - 1) As Byte
record.Data.Read(data, 0, CInt(Fix(record.Data.Length)))
Dim mystr As String = enc.GetString(data)
Console.WriteLine(" {0}", mystr)
Next record
Catch e As Exception
Console.WriteLine("Exception {0} {1}", e.GetType(), e.Message)
End Try
Console.WriteLine()
End Sub
Uwagi
Ta metoda zwraca wyliczalną kolekcję rekordów w sekwencji. Kolejność wyliczonych rekordów zależy od wartości parametru logRecordEnum
.