내보내기(0) 인쇄
모두 확장
확장 최소화
이 문서는 수동으로 번역한 것입니다. 원본 텍스트를 보려면 포인터를 문서의 문장 위로 올리십시오. 추가 정보
번역
원본

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

조건

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

              
                9973은 소수입니다.
              
              
                9967는 소수입니다.
              
              
                9949은 소수입니다.
              
              
                9941은 소수입니다.
              
              
                9931은 소수입니다.
              
            

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

Windows Windows 서버 2012, Windows Server 2008 R2, Windows 7, 8

F# 코어 라이브러리 버전

지원: 2.0, 4.0, 노트북

커뮤니티 추가 항목

추가
표시:
© 2015 Microsoft