다음을 통해 공유


Seq.cache<'T> 함수(F#)

업데이트: 2010년 8월

입력 시퀀스의 캐시된 버전에 해당하는 시퀀스를 반환합니다.

네임스페이스/모듈 경로: Microsoft.FSharp.Collections.Seq

어셈블리: FSharp.Core(FSharp.Core.dll)

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

// Usage:
Seq.cache source

매개 변수

  • source
    형식: seq<'T>

    입력 시퀀스입니다.

예외

Exception

조건

ArgumentNullException

입력 시퀀스가 null인 경우 throw됩니다.

반환 값

결과 시퀀스입니다.

설명

이 결과 시퀀스에는 입력 시퀀스와 동일한 요소가 포함됩니다. 결과를 여러 번 열거할 수 있습니다. 입력 시퀀스는 필요한 경우 한 번만 열거됩니다. 시퀀스 캐싱은 일반적으로 원본 시퀀스에서 반복적으로 계산되는 항목으로 인해 많은 계산 과정이 필요하거나 시퀀스 반복으로 인해 사용자가 여러 번 반복하지 않으려는 항목이 반복되는 등의 경우에 유용합니다. 입력 시퀀스의 열거가 시작된 후 해당 열거자는 열거가 완료될 때까지 이 개체에 의해 활성 상태가 유지됩니다. 열거가 완료되면 열거자가 삭제됩니다. 반환된 시퀀스 개체를 IDisposable 형식으로 변환하고 이 개체에서 Dispose 메서드를 호출하면 열거자가 삭제되고 내부 캐시 저장소가 해제될 수 있습니다. 그런 다음 시퀀스 개체가 다시 열거되고 최신 열거자가 사용됩니다.

컴파일된 어셈블리에서 이 함수의 이름은 Cache입니다. F# 이외의 언어에서 함수에 액세스하거나 리플렉션을 통해 함수에 액세스하는 경우 이 이름을 사용합니다.

예제

다음 코드 예제에서는 Seq.cache를 사용하여 시퀀스의 요소를 다시 계산하지 않도록 방지하는 방법을 보여 줍니다.

// Recursive isprime function.
let isPrime n =
    let rec check i =
        i > n/2 || (n % i <> 0 && check (i + 1))
    check 2

let seqPrimes = seq { for n in 2 .. 10000 do if isPrime n then yield n }
// Cache the sequence to avoid recomputing the sequence elements.
let cachedSeq = Seq.cache seqPrimes
for index in 1..5 do
    printfn "%d is prime." (Seq.nth (Seq.length cachedSeq - index) cachedSeq)

Output

            

스레드로부터의 안전성

결과 시퀀스 열거는 여러 독립적 IEnumerator 값을 서로 다른 여러 스레드에서 동시에 사용할 수 있다는 점에서 스레드로부터 안전합니다(내부 참조 테이블에 대한 액세스가 스레드로부터 안전함). 일반적으로 개별 IEnumerator는 스레드로부터 안전하지 않으므로 동시에 액세스해서는 안 됩니다.

플랫폼

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

버전 정보

F# 런타임

지원되는 버전: 2.0, 4.0

Silverlight

지원되는 버전: 3

참고 항목

참조

Collections.Seq 모듈(F#)

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

변경 기록

날짜

변경 내용

이유

2010년 8월

코드 예제를 추가했습니다.

향상된 기능 관련 정보