Функция Seq.readonly<'T> (F#)
Создает новый объект последовательности, который делегируется данному объекту последовательности.Таким образом гарантируется, что первоначальную последовательность нельзя обнаружить повторно и изменить приведением типов.Например, если задан массив, возвращенная последовательность вернет все элементы массива, но при этом нельзя преобразовать объект последовательности в массив.
Пространство имен/путь к модулю: Microsoft.FSharp.Collections.Seq
Сборка: FSharp.Core (в FSharp.Core.dll)
// Signature:
Seq.readonly : seq<'T> -> seq<'T>
// Usage:
Seq.readonly source
Параметры
source
Тип: seq<'T>Входная последовательность.
Исключения
Исключение |
Атрибут Condition |
---|---|
Создается при указании в качестве входной последовательности значения NULL. |
Возвращаемое значение
Результирующая последовательность.
Заметки
В скомпилированных сборках имя этой функции — ReadOnly.При обращении к функции из языка, отличного от F#, или посредством отражения следует использовать это имя.
Пример
В следующем коде используется Seq.readonly для создания неизменныого представления изменяемого массива.
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
Платформы
Windows 8, Windows 7, Windows Server 2012, Windows 2008 Server R2
Сведения о версии
Основной версии библиотеки F#
Поддерживается в: 2.0, 4.0, портативное