W3Cschool
恭喜您成為首批注冊(cè)用戶
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
在F#中,函數(shù)的工作就像數(shù)據(jù)類型??梢月暶骱腿魏纹渌兞肯嗤姆绞绞褂玫墓δ堋?
由于函數(shù)可以像任何其他變量可以使用,你可以 -
功能通過(guò)使用let關(guān)鍵字定義。函數(shù)定義的語(yǔ)法如下 -
let [inline] function-name parameter-list [ : return-type ] = function-body
函數(shù)名是表示函數(shù)的標(biāo)識(shí)符。
參數(shù)列表給出了用空格分隔參數(shù)列表。您還可以指定一個(gè)顯式類型的每一個(gè)參數(shù),如果沒(méi)有指定編譯器傾向于從函數(shù)體(如變量)推斷出結(jié)論。
函數(shù)體由一個(gè)表達(dá)式,或者由若干表達(dá)式的化合物的表情。函數(shù)體中最后一個(gè)表達(dá)式返回值。
返回型是冒號(hào)后跟一個(gè)類型并且是可選的。如果沒(méi)有指定返回類型,則編譯器在函數(shù)體中最后一個(gè)表達(dá)式?jīng)Q定了它。
你函數(shù)名之后列出的參數(shù)名稱。可以指定參數(shù)的類型。參數(shù)類型應(yīng)遵循由冒號(hào)分隔參數(shù)的名稱。
如果沒(méi)有指定參數(shù)類型,它是由編譯器推斷。
例如 -
let doubleIt (x : int) = 2 * x
一個(gè)函數(shù)可以通過(guò)指定函數(shù)名稱,后跟一個(gè)空格,然后用空格分隔任何參數(shù)調(diào)用。
例如 -
let vol = cylinderVolume 3.0 5.0
下面的程序演示的概念。
以下程序計(jì)算時(shí)的半徑和長(zhǎng)度給定為參數(shù)的圓柱體的體積。
// the function calculates the volume of // a cylinder with radius and length as parameters let cylinderVolume radius length : float = // function body let pi = 3.14159 length * pi * radius * radius let vol = cylinderVolume 3.0 5.0 printfn " Volume: %g " vol
當(dāng)你編譯和執(zhí)行程序,它產(chǎn)生以下輸出 -
Volume: 141.372
下列程序返回的兩個(gè)給定參數(shù)的較大值 -
// the function returns the larger value between two // arguments let max num1 num2 : int32 = // function body if(num1>num2)then num1 else num2 let res = max 39 52 printfn " Max Value: %d " res
當(dāng)你編譯和執(zhí)行程序,它產(chǎn)生以下輸出 -
Max Value: 52
let doubleIt (x : int) = 2 * x printfn "Double 19: %d" ( doubleIt(19))
當(dāng)你編譯和執(zhí)行程序,它產(chǎn)生以下輸出 -
Double 19: 38
遞歸函數(shù)是自稱的功能。
您可以定義使用let rec關(guān)鍵字組合遞歸。
語(yǔ)法定義遞歸函數(shù)是
//Recursive function definition let rec function-name parameter-list = recursive-function-body
例如 -
let rec fib n = if n < 2 then 1 else fib (n - 1) + fib (n - 2)
以下程序返回Fibonacci 1到10
let rec fib n = if n < 2 then 1 else fib (n - 1) + fib (n - 2) for i = 1 to 10 do printfn "Fibonacci %d: %d" i (fib i)
當(dāng)你編譯和執(zhí)行程序,它產(chǎn)生以下輸出
Fibonacci 1: 1 Fibonacci 2: 2 Fibonacci 3: 3 Fibonacci 4: 5 Fibonacci 5: 8 Fibonacci 6: 13 Fibonacci 7: 21 Fibonacci 8: 34 Fibonacci 9: 55 Fibonacci 10: 89
以下程序返回factorial 8
open System let rec fact x = if x < 1 then 1 else x * fact (x - 1) Console.WriteLine(fact 8)
當(dāng)你編譯和執(zhí)行程序,它產(chǎn)生以下輸出 -
40320
int -> string
數(shù)據(jù)類型讀左到右。
讓我們假設(shè)另外一個(gè)功能,它有兩個(gè)int數(shù)據(jù)輸入,并返回一個(gè)字符串。
let mydivfunction x y = (x / y).ToString();;
F#報(bào)告使用鏈?zhǔn)郊^符號(hào)作為數(shù)據(jù)類型 -
val mydivfunction : x:int -> y:int -> string
返回類型由鏈?zhǔn)郊^符號(hào)最右邊的數(shù)據(jù)類型來(lái)表示。
更多的例子
符號(hào) | 含義 |
---|---|
float → float → float | 該函數(shù)需要兩個(gè)輸入,返回另一個(gè)。 |
int → string → float | 該函數(shù)接受ainting astringinput,返回float。 |
lambda表達(dá)式是匿名函數(shù)。
讓我們以兩個(gè)函數(shù)作為例子
let applyFunction ( f: int -> int -> int) x y = f x y let mul x y = x * y let res = applyFunction mul 5 7 printfn "%d" res
當(dāng)你編譯和執(zhí)行程序,它產(chǎn)生以下輸出 -
35
現(xiàn)在在上面的例子中,而不是定義函數(shù),我們可以使用lambda表達(dá)式
let applyFunction ( f: int -> int -> int) x y = f x y let res = applyFunction (fun x y -> x * y ) 5 7 printfn "%d" res
當(dāng)你編譯和執(zhí)行程序,它產(chǎn)生以下輸出 -
35
在F#中,一個(gè)功能可以從其他的功能組成。
下面的示例顯示了一個(gè)名為女,來(lái)自兩個(gè)函數(shù)功能1和功能2功能組成 -
let function1 x = x + 1 let function2 x = x * 5 let f = function1 >> function2 let res = f 10 printfn "%d" res
當(dāng)你編譯和執(zhí)行程序,它產(chǎn)生以下輸出 -
55
F#還提供了一個(gè)叫做pipelining of functions的功能。流水線中,函數(shù)調(diào)用作為連續(xù)操作進(jìn)行鏈接在一起。
下面的例子說(shuō)明
let function1 x = x + 1 let function2 x = x * 5 let res = 10 |> function1 |> function2 printfn "%d" res
當(dāng)你編譯和執(zhí)行程序,它產(chǎn)生以下輸出
55
Copyright©2021 w3cschool編程獅|閩ICP備15016281號(hào)-3|閩公網(wǎng)安備35020302033924號(hào)
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號(hào)
聯(lián)系方式:
更多建議: