Seq.cache<'T> 함수(F#)
입력 시퀀스의 캐시된 버전에 해당하는 시퀀스를 반환합니다.
네임스페이스/모듈 경로: Microsoft.FSharp.Collections.Seq
어셈블리: FSharp.Core(FSharp.Core.dll)
// Signature:
Seq.cache : seq<'T> -> seq<'T>
// Usage:
Seq.cache source
매개 변수
source
형식: seq<'T>입력 시퀀스입니다.
예외
Exception |
조건 |
---|---|
입력 시퀀스가 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 Windows 서버 2012, Windows Server 2008 R2, Windows 7, 8
버전 정보
F# 코어 라이브러리 버전
지원: 2.0, 4.0, 노트북