1 详解scala中的类
基本思路还是跟到官网文档走,遇到一些特别的点,增加对应的补充。 官网文档:https://docs.scala-lang.org/zh-cn/tour/classes.html Scala中的类是用于创建对象的蓝图,其中包含了方法、常量、变量、类型、对象、特质、类,这些统称为成员。
1-1 类定义
一个最简的类的定义就是关键字class+标识符,类名首字母应大写。
class User
val user1 = new User
关键字new被用于创建类的实例。User由于没有定义任何构造器,因而只有一个不带任何参数的默认构造器。然而,你通常需要一个构造器和类体。
object ScalaTest {
def main( args: Array[ String ] ) : Unit = {
class Point( var x: Int , var y: Int ) {
def move( dx: Int , dy: Int ) : Unit = {
x = x + dx
y = y + dy
}
override def toString: String =
s"($x, $y)"
}
val point1 = new Point( 2 , 3 )
point1. x
println( point1)
}
}
( 2, 3)
Point类有4个成员:变量x和y,方法move和toString。 与许多其他语言不同,主构造方法在类的签名中(var x: Int, var y: Int)。 move方法带有2个参数,返回无任何意义的Unit类型值()。这一点与Java这类语言中的void相当。 另外,toString方法不带任何参数但是返回一个String值。因为toString覆盖了AnyRef中的toString方法,所以用了override关键字标记。
1-1 构造器
object ScalaTest {
def main( args: Array[ String ] ) : Unit = {
class Point( var x: Int = 0 , var y: Int = 0 )
val origin = new Point
val point1 = new Point( 1 )
println( point1. x)
}
}
1
在这个特别说明下,我们在Java是是怎么实现默认值的尼,一般是实现方法的重载实现,这样增加了方法的多多可用。 在scala中通过构造器在实现参数的默认值,来实现的。有点类似mvc中的controller中的 在这个版本的Point类中,x和y拥有默认值0所以没有必传参数。然而,因为构造器是从左往右读取参数,所以如果仅仅要传个y的值,你需要带名传参。 这样的做法在实践中有利于使得表达明确无误。
object ScalaTest {
def main( args: Array[ String ] ) : Unit = {
class Point {
private var _x = 0
private var _y = 0
private val bound = 100
def x = _x
def x_= ( newValue: Int ) : Unit = {
if ( newValue < bound) _x = newValue else printWarning
}
def y = _y
def y_= ( newValue: Int ) : Unit = {
if ( newValue < bound) _y = newValue else printWarning
}
private def printWarning = println( "WARNING: Out of bounds" )
override def toString: String = {
s"_x=${_x} _y=${_y}"
}
}
val point1 = new Point
point1. x = 99
point1. y = 101
println( point1. toString)
}
}
在这个版本的Point类中,数据存在私有变量_x和_y中。 def x和def y方法用于访问私有数据。def x_=和def y_=是为了验证和给_x和_y赋值。 注意下对于setter方法的特殊语法:这个方法在getter方法的后面加上_=,后面跟着参数。 主构造方法中带有val和var的参数是公有的。然而由于val是不可变的,所以不能像下面这样去使用。
class Point( val x: Int , val y: Int )
val point = new Point( 1 , 2 )
object ScalaTest {
def main( args: Array[ String ] ) : Unit = {
class Point( x: Int , y: Int )
val point = new Point( 1 , 2 )
}
}