cats是scala的一個新的函數(shù)式編程工具庫,其設(shè)計原理基本繼承了scalaz:大家都是haskell typeclass的scala版實現(xiàn)。當然,cats在scalaz的基礎(chǔ)上從實現(xiàn)細節(jié)、庫組織結(jié)構(gòu)和調(diào)用方式上進行了一些優(yōu)化,所以對用戶來說:cats的基礎(chǔ)數(shù)據(jù)類型、數(shù)據(jù)結(jié)構(gòu)在功能上與scalaz是大致相同的,可能有一些語法上的變化。與scalaz著名抽象、復(fù)雜的語法表現(xiàn)形式相比,cats的語法可能更形象、簡單直白。在scalaz的學習過程中,我們了解到所謂函數(shù)式編程就是monadic Programming:即用monad這樣的數(shù)據(jù)類型來構(gòu)建程序。而實際可行的monadic programming就是用Free-Monad編程了。因為Free-Monad程序是真正可運行的,或者說是可以實現(xiàn)安全運行的,因為它可以保證在固定的堆棧內(nèi)實現(xiàn)無限運算。我們知道:函數(shù)式編程模式的運行方式以遞歸算法為主,flatMap函數(shù)本身就是一種遞歸算法。這就預(yù)示著monadic programming很容易造成堆棧溢出問題(StackOverflowError)。當我們把普通的泛函類型F[A]升格成Free-Monad后就能充分利用Free-Monad安全運算能力來構(gòu)建實際可運行的程序了。由于我們在前面已經(jīng)詳細的了解了scalaz的大部分typeclass,包括Free,對cats的討論就從Free開始,聚焦在cats.Free編程模式方面。同時,我們可以在使用cats.Free的過程中對cats的其它數(shù)據(jù)類型進行補充了解。
cats.Free的類型款式如下:
sealed abstract class Free[S[_], A] extends Product with Serializable {...}
S是個高階類,就是一種函數(shù)式運算。值得注意的是:現(xiàn)在S不需要是個Functor了。因為Free的一個實例Suspend類型是這樣的:
/** Suspend the computation with the given suspension. */ private final case class Suspend[S[_], A](a: S[A]) extends Free[S, A]