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