您好,登錄后才能下訂單哦!
本篇內容介紹了“scala的柯里化是什么”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
方法可以定義多個參數列表,當使用較少的參數列表調用多參數列表的方法時,會產生一個新的函數,該函數接收剩余的參數列表作為其參數。這被稱為柯里化。
下面是一個例子,在Scala集合 trait TraversableOnce
定義了 foldLeft
def foldLeft[B](z: B)(op: (B, A) => B): B
foldLeft
從左到右,以此將一個二元運算op
應用到初始值z
和該迭代器(traversable)的所有元素上。以下是該函數的一個用例:
從初值0開始, 這里 foldLeft
將函數 (m, n) => m + n
依次應用到列表中的每一個元素和之前累積的值上。
val numbers = List(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)val res = numbers.foldLeft(0)((m, n) => m + n)print(res)
多參數列表有更復雜的調用語法,因此應該謹慎使用,建議的使用場景包括:
在某些情況下存在單一的函數參數時,例如上述例子foldLeft
中的op
,多參數列表可以使得傳遞匿名函數作為參數的語法更為簡潔。如果不使用多參數列表,代碼可能像這樣:
numbers.foldLeft(0, {(m: Int, n: Int) => m + n})
注意使用多參數列表時,我們還可以利用Scala的類型推斷來讓代碼更加簡潔(如下所示),而如果沒有多參數列表,這是不可能的。
numbers.foldLeft(0)(_ + _)
像上述語句這樣,我們可以給定多參數列表的一部分參數列表(如上述的z
)來形成一個新的函數(partially applied function),達到復用的目的,如下所示:
val numbers = List(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
val numberFunc = numbers.foldLeft(List[Int]())_
val squares = numberFunc((xs, x) => xs:+ x*x)
print(squares.toString())
val cubes = numberFunc((xs, x) => xs:+ x*x*x)
print(cubes.toString())
最后,foldLeft
和 foldRight
可以按以下任意一種形式使用,
val numbers = List(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
numbers.foldLeft(0)((sum, item) => sum + item)
numbers.foldRight(0)((sum, item) => sum + item)
numbers.foldLeft(0)(_+_)
numbers.foldRight(0)(_+_)
(0 /: numbers)(_+_)
(numbers :\ 0)(_+_)
如果要指定參數列表中的某些參數為隱式(implicit),應該使用多參數列表。例如:
def execute(arg: Int)(implicit ec: ExecutionContext) = ???
“scala的柯里化是什么”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。