AnyRef
的子类java
使用new
构造对象api
当存在默认构造函数,能够略去括号app
AnyRef
等价于java.lang.Object
函数
能够将null
赋值给Reference Type
性能
AnyVal
的子类spa
Char, Byte, Short, Int, Long, Float, Double, Unit, Boolean
scala
不能使用new
构造实例,而使用Literal Values
构造实例code
编译器将其映射为Java
原生类型,以便提高性能对象
不能将null
赋值给Int
的变量ci
以Int
为例,其定义相似于:
final abstract class Int private extends AnyVal
final
表示不能被子类化
abstract
表示不能被实例化
private
表示主构造函数私有化,进一步保证不能被实例化
extends AnyVal
表示只能使用字面值构造实例
Unit
与()
Unit
类型在JVM
中对应于Java
的void
。
final abstract class Unit private extends AnyVal
()
是其惟一的实例。
classOf[Unit] // Class[Unit] = void ().getClass // Class[Unit] = void classTag[Unit] // scala.reflect.ClassTag[Unit] = Unit classTag[Unit].runtimeClass // Class[_] = void
具备返回值类型为Unit
的函数经常被称为「过程」(Procedure
)。
def update(i: Int, value: Char): Unit = { ... }
经常忽略Unit =
,Scala
默认推演为Unit
。上例等价于
def update(i: Int, value: Char) { ... }
返回值为Unit
的函数,表明了「反作用」语义;从某种意义上讲,「过程」是一种反函数式的思惟。
Null
与null
Null
是全部AnyRef
的子类型,存在惟一的实例null
。不能将null
赋予「值类型」,例如Int, Boolean
等。
val num: Int = null // Compile Error
'1th '2th
若是符号中有空格,能够是使用Symbol::apply
直接构造
Symbol("Programming Scala")
(1, "two")
等价于Tuple2(1, "twp")
,或者Tuple2[Int, String](1, "two")
。
val t1 = (1, "two") val t1: (Int,String) = (1, "two") val t2: Tuple2[Int,String] = (1, "two")
(i: Int, s: String) => s+i
是类型为Function2[Int, String, String]
的一个字面值。
字面值的类型定义经常用于类型声明,以下三个变量定义是相同的:
val f1: (Int, String) => String = (i, s) => s + i val f2 = (i: Int, s: String) => s + i val f3: Function2[Int, String, String] = (i, s) => s+ i
val capital = Map("US" -> "Washington", "France" -> "Paris")
"US" -> "Washington"
构造了一个类型为Tuple2[String, String]
的二元组:("US", "Washington")
。
package scala object Predef { implicit final class ArrowAssoc[A](private val self: A) extends AnyVal { def ->[B](y: B) = (self, y) } }
val regex = "([0-9]+) ([a-z]+)".r
须要注意的是,r
并不是java.lang.String
的方法,Scala
拥有一套完备的机制加强既有类库的能力。