다음을 통해 공유


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>

    입력 시퀀스입니다.

예외

Exception

조건

ArgumentNullException

입력 시퀀스가 null이면 throw됩니다.

반환 값

결과 시퀀스입니다.

설명

컴파일된 어셈블리에서 이 함수의 이름은 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 Windows 서버 2012, Windows Server 2008 R2, Windows 7, 8

버전 정보

F# 코어 라이브러리 버전

지원: 2.0, 4.0, 노트북

참고 항목

참조

Collections.Seq 모듈(F#)

Microsoft.FSharp.Collections 네임스페이스(F#)