다음을 통해 공유


Option.fold<'T,'State> 함수(F#)

업데이트: 2010년 5월

한 옵션에 대해 동일한 List.fold를 계산합니다.

네임스페이스/모듈 경로: Microsoft.FSharp.Core.Option

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

// Signature:
fold : ('State -> 'T -> 'State) -> 'State -> 'T option -> 'State

// Usage:
fold folder state option

매개 변수

  • folder
    형식: 'State -> 'T -> 'State

    옵션에서 값이 지정될 때 상태 데이터를 업데이트하는 함수입니다.

  • state
    형식: 'State

    초기 상태입니다.

  • option
    형식: 'T option

    입력 옵션입니다.

반환 값

옵션이 None이면 원래 상태이고, 그렇지 않으면 폴더 및 옵션 값으로 업데이트된 상태를 반환합니다.

설명

식 fold f s inp는 match inp with None -> s | Some x -> f s x으로 계산됩니다.

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

예제

다음 코드에서는 Option.fold의 사용 예를 보여 줍니다.

let consOption list opt =
    Option.fold (fun state value -> value :: state) list opt
printfn "%A" <| consOption [1 .. 10] None
printfn "%A" <| consOption [1 .. 10] (Some(0))

// Read input from the console, and if the input parses as
// an integer, cons to the list.
let readNumber () =
    let line = System.Console.ReadLine()
    let (success, value) = System.Int32.TryParse(line)
    if success then Some(value) else None
let mutable list1 = []
let mutable count = 0
while count < 5 do
    printfn "Enter a number: "
    list1 <- consOption list1 (readNumber())
    printfn "New list: %A" <| list1
    count <- count + 1

Output

  

플랫폼

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

참고 항목

참조

Core.Option 모듈(F#)

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

변경 기록

날짜

변경 내용

이유

2010년 5월

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

향상된 기능 관련 정보