Scala学习之路之篇六(类与对象)
Scala 类和对象
类是对象的抽象,而对象是类的具体实例。
类是抽象的,不占用内存,而对象是具体的,占用存储空间。
Scala中的类不声明为public,一个Scala源文件中可以有多个类。
类定义(类 class)
class Point(xc: Int, yc: Int) {var x: Int = xcvar y: Int = ycdef move(dx: Int, dy: Int) {x = x + dxy = y + dyprintln ("x 的坐标点: " + x);println ("y 的坐标点: " + y);}
}
以上实例的类定义了两个变量 x 和 y ,一个方法:move,方法没有返回值。
Scala 的类定义可以有参数,称为类参数,如上面的 xc, yc,类参数在整个类中都可以访问。
实例化类(对象 object)
可以使用 new 来实例化类,并访问类中的方法和变量:
import java.io._class Point(xc: Int, yc: Int) {var x: Int = xcvar y: Int = ycdef move(dx: Int, dy: Int) {x = x + dxy = y + dyprintln ("x 的坐标点: " + x);println ("y 的坐标点: " + y);}
}object Test {def main(args: Array[String]) {val pt = new Point(10, 20);// 移到一个新的位置pt.move(10, 10);}
}
Scala 继承
Scala继承一个基类跟Java很相似, 但我们需要注意以下几点:
1、重写一个非抽象方法必须使用override修饰符;
2、只有主构造函数才可以往基类的构造函数里写参数;
3、在子类中重写超类的抽象方法时,你不需要使用override关键字。
4、继承会继承父类的所有属性和方法,Scala 只允许继承一个父类。
class Point(xc: Int, yc: Int) {var x: Int = xcvar y: Int = ycdef move(dx: Int, dy: Int) {x = x + dxy = y + dyprintln ("x 的坐标点: " + x);println ("y 的坐标点: " + y);}
}class Location(override val xc: Int, override val yc: Int, // override val xc 为重写了父类的字段val zc :Int) extends Point(xc, yc){var z: Int = zcdef move(dx: Int, dy: Int, dz: Int) {x = x + dxy = y + dyz = z + dzprintln ("x 的坐标点 : " + x);println ("y 的坐标点 : " + y);println ("z 的坐标点 : " + z);}
}
Scala 使用 extends 关键字来继承一个类。
实例中 Location 类继承了 Point 类。Point 称为父类(基类),Location 称为子类。
import java.io._class Point(val xc: Int, val yc: Int) {var x: Int = xcvar y: Int = ycdef move(dx: Int, dy: Int) {x = x + dxy = y + dyprintln ("x 的坐标点 : " + x);println ("y 的坐标点 : " + y);}
}class Location(override val xc: Int, override val yc: Int,val zc :Int) extends Point(xc, yc){var z: Int = zcdef move(dx: Int, dy: Int, dz: Int) {x = x + dxy = y + dyz = z + dzprintln ("x 的坐标点 : " + x);println ("y 的坐标点 : " + y);println ("z 的坐标点 : " + z);}
}object Test {def main(args: Array[String]) {val loc = new Location(10, 20, 15);// 移到一个新的位置loc.move(10, 10, 5);}
}
Scala 重写一个非抽象方法
Scala重写一个非抽象方法,必须用override修饰符。
class Person {var name = ""override def toString = getClass.getName + "[name=" + name + "]" // getClass.getName得到当前所用类名
}class Employee extends Person {var salary = 0.0override def toString = super.toString + "[salary=" + salary + "]"
}object Test extends App {val fred = new Employee // getClass.getName得到当前所用类名fred.name = "Fred"fred.salary = 50000println(fred)
}
Scala 单例对象、伴生对象
单例对象实例
在 Scala 中,是没有 static 这个东西的,但是它也为我们提供了单例模式的实现方法,那就是使用关键字 object。
import java.io._class Point(val xc: Int, val yc: Int) {var x: Int = xcvar y: Int = ycdef move(dx: Int, dy: Int) {x = x + dxy = y + dy}
}object Test {def main(args: Array[String]) {val point = new Point(10, 20)printPointdef printPoint{println ("x 的坐标点 : " + point.x);println ("y 的坐标点 : " + point.y);}}
}
伴生对象实例
Scala 中使用单例模式时,除了定义的类之外,还要定义一个同名的 object 对象,它和类的区别是,object对象不能带参数。
当单例对象与某个类共享同一个名称时,他被称作是这个类的伴生对象:companion object。
你必须在同一个源文件里定义类和它的伴生对象。类被称为是这个单例对象的伴生类:companion class。
类和它的伴生对象可以互相访问其私有成员。
实例1:私有构造方法
class Marker private(val color:String) {println("创建" + this) // 在scala中,this是一个关键字,用于引用当前对象。可以使用this关键字调用实例变量,方法,构造函数。override def toString(): String = "颜色标记:"+ color // toString方法会在打印时自动调用}// -------伴生对象,与类名字相同,可以访问类的私有属性和方法
object Marker{private val markers: Map[String, Marker] = Map( // Map映射 (相当于python中的字典)"red" -> new Marker("red"),"blue" -> new Marker("blue"),"green" -> new Marker("green"))def apply(color:String) = {if(markers.contains(color)) markers(color) else null}def getMarker(color:String) = { if(markers.contains(color)) markers(color) else null}def main(args: Array[String]) { println(Marker("red")) // 直接会去调用 伴生对象 中的apply方法// 单例函数调用,省略了.(点)符号 println(Marker getMarker "blue") }
}
实例2
class ApplyOperation { // 伴生类1
}
class ApplyTest{ // 伴生类2def apply() = println("I am into spark so much!!!")def haveATry: Unit ={println("have a try on apply")}
}
object ApplyTest{ // 伴生对象2def apply() = {println("I am into Scala so much")new ApplyTest // 实例化 伴生类2 ,并返回}
}
object ApplyOperation{ // 伴生对象1def main (args: Array[String]) { // 程序入口val array= Array(1,2,3,4)val a = ApplyTest() // 调用 伴生对象2 中的 apply 方法a.haveATrya() // 调用 伴生类2 中 apply 方法}
}
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
