快速入门Scala(五):方法与函数

分类目录:《快速入门Scala》总目录

Scala中包含方法与函数,二者在语义上的区别很小。Scala的方法是类的一部分,而函数是一个对象可以赋值给一个变量。Scala 中的方法跟 Java 的类似,方法是组成类的一部分,而函数则是一个完整的对象,Scala中的函数其实就是继承了Trait的类的对象。

方法

Scala方法声明完整格式如下:

def methodName ([参数列表]) : [return type] = {
	//方法体
}

其中,参数列表中的参数可以使用逗号分隔。如果你不写等于号和方法主体,那么方法会被隐式声明为抽象(abstract),包含它的类型于是也是一个抽象类型。

以下是将两个传入的参数相加的方法实例:

scala> def m (x:Int, y:Int): Int = x + y
m: (x: Int, y: Int)Int

也可以不指明方法的返回值类型,Scala会自动推断返回值类型:

scala> def m (x:Int, y:Int) = x + y
m: (x: Int, y: Int)Int

如果方法没有返回值,则默认返回Unit:

scala> def hello():Unit = {
| println("Hello World!")
| }
hello: ()Unit

在调用方法时,使用:

methodName ([参数列表])

比如我们要调用上文定义的m函数,对1和2进行求和:

scala> m(1, 2)
res0: Int = 3

函数

在Scala中常使用匿名函数。顾名思义,就是没有名字的函数。它可以作为函数的参数,也可以直接赋值给变量。

scala> val f = (x:Int, y:Int) => x + y
f: (Int, Int) => Int = $$Lambda$1012/2144659477@4cffd3fd

scala> f(1,2)
res0: Int = 3

Scala的函数在定义的时候还可以详细写明参数列表与返回值类型:

scala> val f:Int => (Int, Int, Int) = x => (x, x*x, x*x*x)
f: Int => (Int, Int, Int) = $$Lambda$1259/145332617@53f68c97

你可能感兴趣的:(Scala,Spark,快速入门Scala)