閉包是乙個函式,返回值依賴於宣告在函式外部的乙個或多個變數。
閉包通常來講可以簡單的認為是可以訪問乙個函式裡面區域性變數的另外乙個函式。
如下面這段匿名的函式:
val multiplier = (i:int) => i * 10
函式體內有乙個變數 i,它作為函式的乙個引數。如下面的另一段**:
val multiplier = (i:int) => i * factor
在 multiplier 中有兩個變數:i 和 factor。其中的乙個 i 是函式的形式引數,在 multiplier 函式被呼叫時,i 被賦予乙個新的值。然而,factor不是形式引數,而是自由變數,考慮下面**:
var factor = 3val multiplier = (i:int) => i * factor
這裡我們引入乙個自由變數 factor,這個變數定義在函式外面。
這樣定義的函式變數 multiplier 成為乙個"閉包",因為它引用到函式外面定義的變數,定義這個函式的過程是將這個自由變數捕獲而構成乙個封閉的函式。
完整例項:
object testvar factor = 3
val multiplier = (i:int) => i * factor
}
執行以上**,輸出結果為:
muliplier(1) value = 3muliplier(2) value = 6
下面我們來變換一下形式:
把這匿名函式,賦值給有參函式.
def mulby(factor:int) = (i:int) => i *factorvar mulby3 = mulby(3) //
函式閉包
var mulby5 = mulby(5) //
函式閉包
完整**:
object functioncloseops/*** mulb 的函式體是通過乙個匿名函式來實現的
* 而該匿名函式(i:int) => i * factor 需要乙個引數 factor 並沒有賦值,而factor來自於前面的函式
* 程式執行過程:
* 首先,在**中定義了兩個函式
* 第乙個是: mulby
* 第二個是匿名函式
* 其次, 執行函式mulby,並賦值給mulby3,這樣就把factor的值賦值成了 3 ,
* 函式執行完畢後,就進行了彈棧 mulby3 就實現了匿名函式
* 然後 匿名函式 (i:int) => i * factor 壓棧,
* 最後呼叫 mulby3(10) 把 10 賦值給 i, 完成最終計算
** 在這過程中 匿名函式(i:int) => i * factor 呼叫了乙個不在其作用域範圍的變數 factor,先彈棧,然後將factor儲存到匿名函式
* 最後匿名函式中呼叫了factor.
* 我們把這種結構呼叫了閉包
*/def mulby(factor:int) = (i:int) => i * factor
var mulby3 = mulby(3) //函式閉包
var mulby5 = mulby(5) //函式閉包}
Scala的閉包和柯里化
1 scala中的閉包 閉包是指有權訪問另外乙個函式作用域中的變數的函式。可以理解為能夠讀取另乙個函式作用域的變數的函式。乙個函式的函式體是乙個新的函式,這個函式體函式是閉包 有權訪問另外乙個函式作用域中的變數 閉包可以作為函式引數傳遞 val filteralllogclasrdd casecla...
理解Scala閉包和柯里化
柯里化 def add a int b int a b 等價於 def add a int,b int a bpackage com.zhengkw.scala.day03 classname closure author zhengkw description date 20 04 22下午 3 ...
閉包與柯里化
一 柯里化的概念 在電腦科學中,柯里化是把接受多個引數的函式變換成接受乙個單一引數 最初函式的第乙個引數 的函式,並且返回接受餘下的引數且返回結果的新函式的技術。這個技術由christopher strachey以邏輯學家 haskell curry 命名的,儘管它是 moses schnfinke...