您好,登錄后才能下訂單哦!
本篇內容主要講解“Scala中的閉包和柯里化是什么意思”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Scala中的閉包和柯里化是什么意思”吧!
scala> def add(x:Int, y: Int) = x + y
add: (x: Int, y: Int)Int
scala> add(1, 2)
res0: Int = 3
函數
scala> val add_f = (x: Int, y: Int) => x + y
add_f: (Int, Int) => Int = <function2>
根據內容可以看出add_f是一個函數Function
scala> add_f(1, 2)
res1: Int = 3
首先應該要知道=號右邊的內容 (x: Int, y: Int) => x + y是一個函數體
方法只能用def接收,函數可以用def接收,也可以用val接收。
當函數用def來接收之后,不再顯示為function,轉換為方法
方法可以省略參數,函數不可以。函數可以作為方法的參數。
scala> val a = () => 100
a: () => Int = <function0>
scala> val a = => 100
<console>:1: error: illegal start of simple expression
看這里: val a = => 100 // 當函數參數為空時報錯
理解閉包
scala> def add(x:Int) = (y:Int) => x + y
addBase: (x: Int)Int => Int
(y:Int) => x + y 是一個函數體只是左右省略了花括號!
add可以理解為返回值為函數的方法
當給方法具體參數時,返回一個具體的函數,方法參數不同時,返回的函數也不同。例如
看下面:
scala> val addOne = add(1)
addOne: Int => Int = <function1>
scala> addOne(3)
res2: Int = 4
再看:
scala> val addTwo = add(2)
addTwo: Int => Int = <function1>
scala> addTwo(3)
res3: Int = 5
這時就可以引入閉包的概念了。
在塊中可以參照外部局部變量的方法,并說明塊不只是簡單的代碼,而且把外部“環境”也包括了進來,像這樣的塊稱為閉包。通常的局部變量在方法執行結束時就不存在了,但是如果被包括進了閉包,那么在閉包存在的期間,局部變量也會一直存在。
也就是說,函數體受外部環境所影響,一段封閉的代碼塊將外部環境(函數外部的上下文環境)包括進來,就是閉包。
柯里化指的是將原來接受N個參數的方法變成新的接受一個參數的函數的過程。
其實上面閉包的代碼就是柯里化的過程。以下是柯里化第二種寫法。
scala> def add(x:Int)(y:Int) = x + y
add: (x: Int)(y: Int)Int
scala> add(2)(3) //直接調用試試
res5: Int = 5
柯里化調用試試,繼續執行下面
scala> val addOne = add(1) _
addOne: Int => Int = <function1>
scala> addOne(3)
res6: Int = 4
繼續執行下面
scala> val addTwo = add(2) _
addTwo: Int => Int = <function1>
scala> addTwo(3)
res7: Int = 5
(個人理解柯里化和復合函數有點類似):
scala> def add(x:Int)(y:Int)(z:Int) = {x+y+z}
add: (x: Int)(y: Int)(z: Int)Int
scala> add(10)(20)(30)
res1: Int = 60
//返回值理解為一個函數
scala> val addOne = add(100)_
addOne: Int => (Int => Int) = $$Lambda$1131/181022659@36df4c26
//返回值理解為一個函數
scala> val addTwo = addOne(200)
addTwo: Int => Int = $$Lambda$1134/1397187309@6c421123
//返回值已經不再是一個函數
scala> val sum = addTwo(300)
sum: Int = 600
百度百科定義:在計算機科學中,柯里化(Currying)是把接受多個參數的函數變換成接受一個單一參數(最初函數的第一個參數)的函數,并且返回接受余下的參數且返回結果的新函數的技術。這個技術由 Christopher Strachey 以邏輯學家 Haskell Curry 命名的,盡管它是 Moses Schnfinkel 和 Gottlob Frege 發明的。
從數學的角度講,這是一個對函數消元求解的過程:
def f(x:Int,y:Int)=x+y
def g(x:Int)=f(x,1)
def z=g(1)
z=2
那么z也可以寫成這樣:def z=(x:Int)=>(y:Int)=>x+y
到此,相信大家對“Scala中的閉包和柯里化是什么意思”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。