FileRecordSequence.ReadLogRecords Método

Definição

Devolve uma coleção enumerável de registos na sequência. Este método não pode ser herdado.

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)

Parâmetros

start
SequenceNumber

O número de sequência do primeiro registo onde a leitura começa.

logRecordEnum
LogRecordEnumeratorType

Um valor válido LogRecordEnumeratorType que especifica a forma (isto é, para frente ou para trás) em que os registos devem ser lidos a partir de um LogRecordSequence.

Devoluções

Uma coleção enumerável de registos na sequência.

Implementações

Exceções

Um ou mais dos argumentos estão fora do alcance.

A operação não pode ser realizada porque a sequência de registos foi aberta com acesso apenas de escrita.

A sequência de registos está corrompida.

-ou-

O disco foi escrito com uma versão incompatível da sequência de discos.

A enumeração terminou.

-ou-

A enumeração ainda não foi iniciada. É preciso fazer uma chamada MoveNext() .

O método era chamado depois de a sequência ter sido eliminada.

Não há memória suficiente para continuar a execução do programa.

Exemplos

O exemplo seguinte mostra como pode usar este método para ler os registos numa sequência logarítmica.

// 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

Observações

Este método devolve uma coleção enumerável de registos na sequência. A ordem dos registos enumerados depende do valor do logRecordEnum parâmetro.

Aplica-se a