码迷,mamicode.com
首页 > 其他好文 > 详细

Scala 学习笔记之集合(2)

时间:2017-06-25 20:46:37      阅读:139      评论:0      收藏:0      [点我收藏+]

标签:运行   address   ==   sha   strong   hello   reducer   函数   string   

class StudentTT extends StudentT{
  def sayBye(name: String, age: Int)(address: String){
    println("Hello, " + name + ":" + age + ":" + address)
  }
  
}

object CollectionDemo3 {
  def main(args: Array[String]): Unit = {
    val s = new StudentTT()
    //Currying
    s.sayBye("leo", 1)("shanghai")
    //给定一个起始值0,使用规约函数规约列表,这里其实就是所有元素求和
    println(List(1,2,3).fold(0)(_+_))
    //给定一个起始值0,使用规约函数从左至右规约列表,这里其实就是所有元素求和
    println(List(1,2,3).foldLeft(0)(_+_))
    //给定一个起始值0,使用规约函数从右至左规约列表,这里其实就是所有元素求和
    println(List(1,2,3).foldLeft(0)(_+_))
    //给定一个规约函数,从第一个元素开始规约
    println(List(1,2,3) reduce(_+_))
    //给定一个规约函数,第一个元素从左到右开始规约
    println(List(1,2,3) reduceLeft(_+_))
    //给定一个规约函数,第一个元素从右到左开始规约
    println(List(1,2,3) reduceRight(_+_))
    //给定一个起始值0,使用规约函数,生成一个归约值得列表
    println(List(1,2,3).scan(0)(_+_))
    //给定一个起始值0,使用规约函数从左至右,生成一个归约值得列表
    println(List(1,2,3).scanLeft(0)(_+_))   
    //给定一个起始值0,使用规约函数从右至左,生成一个归约值得列表
    println(List(1,2,3).scanRight(0)(_+_))
    //复杂的归约,如果你一看就懂,说明你真的掌握了,我当时认真看了一会才看明白。。。
    println(List(1,2,3).foldLeft(false){(a, i) => if(a) a else (i ==2)})
    
  }
}

运行结果:

Hello, leo:1:shanghai
6
6
6
6
6
6
List(0, 1, 3, 6)
List(0, 1, 3, 6)
List(6, 5, 3, 0)
true

 

Scala 学习笔记之集合(2)

标签:运行   address   ==   sha   strong   hello   reducer   函数   string   

原文地址:http://www.cnblogs.com/AK47Sonic/p/7077833.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!