Scala的for循环以及field、守卫(guard)笔记

Scala中的yield的是把每次迭代中的有关值,并逐一存入到一个集合中,返回值类型和for循环中的返回值类型一致。

eg1.for循环

//to
scala> for(i <- 2 to 10)
     | print(i+" ")
2 3 4 5 6 7 8 9 10
//until
scala> for(i <- 2 until 10)
     | print(i+" ")
2 3 4 5 6 7 8 9
//定义一个数组
scala> val a = Array(1,3,5,7,9)
a: Array[Int] = Array(1, 3, 5, 7, 9)
//隔两个数迭代
scala> for(a <- 0 until (a.length,2)) yield a
res35: scala.collection.immutable.IndexedSeq[Int] = Vector(0, 2, 4)
//遍历
scala> for (elem <- a) yield elem
res24: Array[Int] = Array(1, 3, 5, 7, 9)

eg2.不对yield迭代后的结果做任何处理

scala> for (i <- 1 to 10) yield i
res4: scala.collection.immutable.IndexedSeq[Int] = Vector(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)

eg3.yield迭代后,集合中每个元素乘以3

scala> for (i <- 1 to 10) yield i*3
res5: scala.collection.immutable.IndexedSeq[Int] = Vector(3, 6, 9, 12, 15, 18, 21, 24, 27, 30)

eg4.守卫(guards)即在for循环中,加上if判断条件,对进行yield的值做限制

scala> for (i <- 1 to 10 if i%2 ==0) yield i*3
res6: scala.collection.immutable.IndexedSeq[Int] = Vector(6, 12, 18, 24, 30)

ps:其他方法

scala> a.filter(_ % 3 == 0).map(2 * _)
res45: Array[Int] = Array(6, 18)
//或者
scala> a.filter(_ % 3 == 0) map(2 * _)//可以使用花括号
res46: Array[Int] = Array(6, 18)

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
一、Scala核心编程课程简介近年来随着大数据的兴起,大数据核心框架Spark和Kafka也受到到广泛关注, Spark底层是Scala实现的, 因此也带火了Scala语言,目前Scala被全球知名公司(如:谷歌、百度、阿里、Twitter、京东等)广泛用于Spark开发。新一代的物联网时代到来,会对大数据应用人才的需求越加紧迫。 尚硅谷网罗和整合了学员很喜爱的师资,打造出专注于Spark开发的Scala课程,我们讲解Scala核心编程技术,同时也讲解编程思想、设计模式和Scala底层实现,让您有豁然开朗的感受。二、课程内容和目标本课程重点讲解Scala核心编程,内容包括: Scala语言概述、运算符、程序流程控制、数据结构之集合、Map映射、过滤、化简、折叠、扫描、拉链、视图、并行集合、高阶函数、函数柯里化、偏函数、参数推断、控制抽象、Trait、面向对象编程、异常处理、惰性函数、Akka及Actor模型、Spark Master和Worker通讯、隐式转换、隐式参数、工厂模式、单例模式、观察者模式、装饰者模式、代理模式、泛型、上下界、视图界定、上下文界定、协变逆变不变和源码剖析。通过系统全面的学习,学员能掌握Scala编程思想和Scala底层机制,为进一步学习Spark打下坚实基础。三、谁适合学1.希望以较低的投入和风险,来了解自己是否适合转型从事Spark开发的求职人员。2.有一定的Java基础,或者自学过一些Java书籍与视频资料,想系统掌握Scala语言的程序员。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值