函数式编程之美

今天在知乎上看见一段函数式编程,第一感觉是美,所以贴出来,大家一起体会体会。

著作权归作者所有。
商业转载请联系作者获得授权,非商业转载请注明出处。
作者:2gua
链接:http://zhuanlan.zhihu.com/guagua/19752481
来源:知乎

/*
* Scala yield用法
* 作者:2gua
* 2014/05/12
*/

object YieldDemo {
    private val files = (new java.io.File(".")).listFiles

    private def fileLines(file: java.io.File) =
        scala.io.Source.fromFile(file).getLines.toList

    def main(args: Array[String]): Unit = {
        val lineLengths =
        for {
            file <- files
            if file.getName.endsWith(".txt")

            line <- fileLines(file)
            trimmedLine = line.trim
            if trimmedLine.matches(".*棒.*")
        } yield line + ":合计" + trimmedLine.length + "个字。"

        lineLengths.foreach(println)
    }
}
一眼就能看懂代码的意思,但是总觉的不对劲,但看着看着又对劲了。有没有这种感觉。

你可能感兴趣的:(大数据之spark)