Compartilhar via


Seq.ReadOnly <'T>. Função (F#)

Cria um novo objeto de seqüência que delega para o objeto de seqüência de determinada. Isso garante que a seqüência original não pode ser redescoberta e sofrendo mutação por uma conversão de tipo. Por exemplo, se uma matriz de dada a seqüência retornada retornará os elementos da matriz, mas você não pode converter o objeto retornado de seqüência para uma matriz.

Caminho do namespace/módulo: Microsoft.FSharp.Collections.seq

Assembly: FSharp.Core (em FSharp.Core.dll)

// Signature:
Seq.readonly : seq<'T> -> seq<'T>

// Usage:
Seq.readonly source

Parâmetros

  • source
    Tipo: SEQ<'T>

    A seqüência de entrada.

Exceções

Exceção

Condição

ArgumentNullException

Lançada quando a seqüência de entrada é nula.

Valor de retorno

A seqüência de resultado.

Comentários

Esta função é chamada de ReadOnly em módulos (assemblies) compilados. Se você estiver acessando a função de um idioma diferente, por exemplo, F# ou através de reflexão, use esse nome.

Exemplo

O seguinte código usa Seq.readonly para criar um modo de exibição imutável de um array mutáveis.

type ArrayContainer(start, finish) =
    let internalArray = [| start .. finish |]
    member this.RangeSeq = Seq.readonly internalArray
    member this.RangeArray = internalArray

let newArray = new ArrayContainer(1, 10)
let rangeSeq = newArray.RangeSeq
let rangeArray = newArray.RangeArray
// These lines produce an error: 
//let myArray = rangeSeq :> int array
//myArray.[0] <- 0
// The following line does not produce an error. 
// It does not preserve encapsulation.
rangeArray.[0] <- 0

Plataformas

O Windows 7, SP2 do Windows Vista, Windows XP SP3, Windows XP Professional x64 SP2, Windows Server 2008 R2, Windows Server 2008 SP2, Windows Server 2003 SP2

Informações sobre versão

O tempo de execução F#

Compatível com: 2.0, 4.0

Silverlight

Compatível com: 3

Consulte também

Referência

Módulo de Collections.SEQ (F#)

Microsoft.FSharp.Collections Namespace (F#)