Udostępnij za pośrednictwem


FileRecordSequence.ReadLogRecords Metoda

Definicja

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 .

Dotyczy