次の方法で共有


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

出力

  

プラットフォーム

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 月

コード例を追加。

情報の拡充