AmosCloud

Library

Have a Question?

If you have any question you can ask below or enter what you are looking for!

Scala_03【特殊语法】

主要内容

  • Scala类型层次结构
  • 类型转换
  • 算术和操作符重载
  • apply、update方法
  • Option类型
  • 异常

学习目标

  • 了解Scala类型层次结构
  • 掌握类型转换
  • 了解操作符重载
  • 理解方法的隐式调用
  • 掌握Option用法
  • 掌握异常处理

特殊语法

1. 统一的类型体系

1.1 类型层次结构

  • 在Scala中,所有的值都有类型,包括数值和函数。下图阐述了类型层次结构的一个子集。

  • Any是所有类型的超类型,也称为顶级类型。它定义了一些通用的方法如equalshashCodetoStringAny有两个直接子类:AnyValAnyRef

  • AnyVal代表值类型。有9个预定义的非空的值类型分别是:DoubleFloatLongIntShortByteCharUnitBooleanUnit是不带任何意义的值类型,它仅有一个实例可以像这样声明:()。所有的函数必须有返回,所以说有时候Unit也是有用的返回类型。

  • AnyRef代表引用类型。所有非值类型都被定义为引用类型。在Scala中,每个用户自定义的类型都是AnyRef的子类型。如果Scala被应用在Java的运行环境中,AnyRef相当于java.lang.Object

1.2 类型转换

  • 值类型可以按照下面的方向进行转换:

file

  • 例如:
val x: Long = 987654321
val y: Float = x  // 9.8765434E8 (可能会丢失一些精度)

val face: Char = '☺'
val number: Int = face  // 9786
  • 转换是单向,下面这样写将不会通过编译。
val x: Long = 987654321
val y: Float = x  // 9.8765434E8
val z: Long = y  // 编译不通过
  • 类型的强行转换

  • 与Java不同的是Scala的类型转换通过asInstanceOf[目标类型]进行类型强转

val i:Int = 128
val b: Byte = i.asInstanceOf[Byte]
println(b) // -128
  • Nothing和Null

  • Nothing是所有类型的子类型,也称为底部类型。没有一个值是Nothing类型的。它的用途之一是给出非正常终止的信号,如抛出异常、程序退出或者一个无限循环(可以理解为它是一个不对值进行定义的表达式的类型,或者是一个不能正常返回的方法)。

  • Null是所有引用类型的子类型(即AnyRef的任意子类型)。它有一个单例值由关键字null所定义。Null主要是使得Scala满足和其他JVM语言的互操作性,但是几乎不应该在Scala代码中使用。我们将在后面的章节中介绍null的替代方案。

2. 算术和操作符重载

  • +-*/%可以完成和 Java 中相同的工作,但是有一点区别,他们都是方法。你几乎可以用任何符号来为方法命名。

  • 中缀表达式
    Scala中可以将对象.方法(参数)简写为对象 方法 参数

val sum1: Int = 1.+(2)
println(sum1) // 3
val sum2: Int = 1 + 2
println(sum2) // 3

3.apply、update 方法

  • Scala中提供了很多隐式操作用来简化编码的书写量,例如典型的apply和update方法

3.1 apply方法

  • 定义在object中名为apply的一系列方法在调用时可以直接使用对象名(参数)的形式完成调用

  • 例如:使用object和apply方法定义DateUtils工具类实现日期格式转换

object DateUtils {

  def apply(time: Long) = {
    val format = new SimpleDateFormat("yyyy-MM-dd")
    format.format(new Date(time))
  }

  def longDate2yyyyMMdd(time: Long) = {
    val format = new SimpleDateFormat("yyyy-MM-dd")
    format.format(new Date(time))
  }

}

object Test {
  def main(args: Array[String]): Unit = {
    val str: String = DateUtils.longDate2yyyyMMdd(0)
    println(str) //1970-01-01
    val str1: String = DateUtils.apply(0)
    println(str1) //1970-01-01
    val str2: String = DateUtils(0)
    println(str1) //1970-01-01
  }
}

3.2 update方法

  • Scala中不可变数组被定义为Array对象,更新数组中的元素时,可以使用update方法,或其隐式形式

  • 数组对象(索引)=值 等价于 数组对象.update(索引,值)

    val ints = new Array[Int](5)
    ints.update(0, 22) // 将数组索引为0的元素更新为22
    println(java.util.Arrays.toString(ints)) // [22, 0, 0, 0, 0]
    ints(2) = 66 // 将数组索引为2的元素更新为66
    println(java.util.Arrays.toString(ints)) // [22, 0, 66, 0, 0]

4. Option 类型

  • Scala为单个值提供了对象的包装器,表示那种可能存在也可能不存在的值。
  • 他只有两个有效的子类对象,一个是Some,表示某个值,另外一个是None,表示为空,通过Option的使用,避免了使用null、空字符串等方式来表示缺少某个值的做法。

5. 异常

  • 与Java类似的,Scala提供异常处理机制用于终止错误的程序运行和错误提示。

  • 但是Scala没有“受检”异常,我们不需要声明说函数或者方法可能会抛出某种异常。受检异常在编译器被检查,Java必须声明方法所会抛出的异常类型。

  • Java

void javaMethod() throws FileNotFoundException {
    FileReader fileReader = new FileReader("path");
}
  • Scala
def scalaMethod(){
  val reader = new FileReader("path")
}
  • 使用try-catch-finally处理异常并执行终极操作
def scalaMethod() {
  var reader: FileReader = null;
  try {
    reader = new FileReader("path")
  } catch {
    case e: Exception => println("捕获异常")
  } finally {
    reader.close()
  }
}