一、条件表达式if

Scala中的if/else语法结构与Java中的一样,唯一不同的是,Scala中的if表达式是有返回值的。

object ScalaApp extends App {

  val x = "scala"
  val result = if (x.length == 5) "true" else "false"
  print(result)

}

在Java中,每行语句都需要使用;表示结束,但是在Scala中并不需要。除非你在单行语句中写了多行代码。

二、块表达式

在Scala中,可以使用{}块包含一系列表达式,块中最后一个表达式的值就是块的值。

object ScalaApp extends App {

  val result = {
    val a = 1 + 1; val b = 2 + 2; a + b
  }
  print(result)
}

// 输出: 6

如果块中的最后一个表达式没有返回值,则块的返回值是Unit类型。

scala> val result ={ val a = 1 + 1; val b = 2 + 2 }
result: Unit = ()

三、循环表达式while

Scala和大多数语言一样,支持whiledo ... while表达式。

object ScalaApp extends App {

  var n = 0

  while (n < 10) {
    n += 1
    println(n)
  }

  // 循环至少要执行一次
  do {
    println(n)
  } while (n > 10)
}

四、循环表达式for

for循环的基本使用如下:

object ScalaApp extends App {

  // 1.基本使用  输出[1,9)
  for (n <- 1 until 10) {print(n)}

  // 2.使用多个表达式生成器  输出: 11 12 13 21 22 23 31 32 33
  for (i <- 1 to 3; j <- 1 to 3) print(f"${10 * i + j}%3d")

  // 3.使用带条件的表达式生成器  输出: 12 13 21 23 31 32
  for (i <- 1 to 3; j <- 1 to 3 if i != j) print(f"${10 * i + j}%3d")

}

除了基本使用外,还可以使用yield关键字从for循环中产生Vector,这称为for推导式。

scala> for (i <- 1 to 10) yield i * 6
res1: scala.collection.immutable.IndexedSeq[Int] = Vector(6, 12, 18, 24, 30, 36, 42, 48, 54, 60)

五、异常处理try

和Java中一样,支持try...catch...finally语句。

import java.io.{FileNotFoundException, FileReader}

object ScalaApp extends App {

  try {
    val reader = new FileReader("wordCount.txt")
  } catch {
    case ex: FileNotFoundException =>
      ex.printStackTrace()
      println("没有找到对应的文件!")
  } finally {
    println("finally 语句一定会被执行!")
  }
}

这里需要注意的是因为finally语句一定会被执行,所以不要在该语句中返回值,否则返回值会被作为整个try语句的返回值,如下:

scala> def g():Int = try return 1 finally  return  2
g: ()Int

// 方法g()总会返回2
scala> g()
res3: Int = 2

六、条件选择表达式match

match类似于java中的switch语句。

object ScalaApp extends App {

  val elements = Array("A", "B", "C", "D", "E")

  for (elem <- elements) {
    elem match {
      case "A" => println(10)
      case "B" => println(20)
      case "C" => println(30)
      case _ => println(50)
    }
  }
}

但是与Java中的switch有以下三点不同:

  • Scala中的case语句支持任何类型;而Java中case语句仅支持整型、枚举和字符串常量;
  • Scala中每个分支语句后面不需要写break,因为在case语句中break是隐含的,默认就有;
  • 在Scala中match语句是有返回值的,而Java中switch语句是没有返回值的。如下:
object ScalaApp extends App {

  val elements = Array("A", "B", "C", "D", "E")

  for (elem <- elements) {
    val score = elem match {
      case "A" => 10
      case "B" => 20
      case "C" => 30
      case _ => 50
    }
    print(elem + ":" + score + ";")
  }
}
// 输出: A:10;B:20;C:30;D:50;E:50;

七、没有break和continue

额外注意一下:Scala中并不支持Java中的break和continue关键字。

八、输入与输出

在Scala中可以使用print、println、printf打印输出,这与Java中是一样的。如果需要从控制台中获取输入,则可以使用StdIn中定义的各种方法。

val name = StdIn.readLine("Your name: ")
print("Your age: ")
val age = StdIn.readInt()
println(s"Hello, ${name}! Next year, you will be ${age + 1}.")

参考资料

  1. Martin Odersky . Scala编程(第3版)[M] . 电子工业出版社 . 2018-1-1
  2. 凯.S.霍斯特曼 . 快学Scala(第2版)[M] . 电子工业出版社 . 2017-7

更多大数据系列文章可以参见个人 GitHub 开源项目: 程序员大数据入门指南

最新文章

  1. java接口调用——webservice就是一个RPC而已
  2. Android Button上的文字自动变成大写,如何解决呢?
  3. ListView中item的最外层使用margin属性失效
  4. 每天一道LeetCode--237.Delete Node in a Linked List
  5. attitude
  6. windows phone (22) 隐藏元素
  7. php投票练习
  8. Python实现机器人聊天
  9. 利用iscroll实现上拉加载下拉刷新
  10. 【Java】 剑指offer(55-2) 平衡二叉树
  11. codeforces 975C Valhalla Siege
  12. Ubuntu云服务器下mysql授权远程登陆
  13. Python实战(6)单线程和多线程导入mysql数据对比测试
  14. POJ 3580 SuperMemo (splay tree)
  15. 六:SpringCloud-Config
  16. Frequently-Used Network Time Server(Base On NTP:Network Time Protocol)
  17. Linux I/O复用中select poll epoll模型的介绍及其优缺点的比較
  18. log4j笔记:升级2.X版本的日志滚动问题
  19. python实现word2vec训练结果bin文件转txt文件
  20. Qt中显示图像的两种方法

热门文章

  1. Windows 10 应用创建模糊背景窗口的三种方法
  2. DDD实战1
  3. C#中正则表达式使用介绍
  4. UVE开发环境搭建及项目启动
  5. Boost总结汇总
  6. c# WebApi POST请求同时包含数据及其文件
  7. 获取控件中应用的模版的内部的控件,使用LoadContent()方法获取模版跟节点
  8. Android 调试桥(adb)是多种用途的工具
  9. html send mail
  10. 同城快递公司Postmates近日完成1亿美元融资,美国外卖餐饮迎来一波融资热潮