Scala 類和對象
類是對象的抽象,而對象是類的具體實例。類是抽象的,不占用內存,而對象是具體的,占用存儲空間。類是用於創建對象的藍圖,它是一個定義包括在特定類型的對象中的方法和變量的軟件模板。
我們可以使用 new 關鍵字來創建類的對象,實例如下:
實例
var x: Int = xc
var y: Int = yc
def move(dx: Int, dy: Int) {
x = x + dx
y = y + dy
println ("x 的坐標點: " + x);
println ("y 的坐標點: " + y);
}
}
Scala中的類不聲明為public,一個Scala源文件中可以有多個類。
以上實例的類定義了兩個變量 x 和 y ,一個方法:move,方法沒有返回值。
Scala 的類定義可以有參數,稱為類參數,如上麵的 xc, yc,類參數在整個類中都可以訪問。
接著我們可以使用 new 來實例化類,並訪問類中的方法和變量:
實例
class Point(xc: Int, yc: Int) {
var x: Int = xc
var y: Int = yc
def move(dx: Int, dy: Int) {
x = x + dx
y = y + dy
println ("x 的坐標點: " + x);
println ("y 的坐標點: " + y);
}
}
object Test {
def main(args: Array[String]) {
val pt = new Point(10, 20);
// 移到一個新的位置
pt.move(10, 10);
}
}
執行以上代碼,輸出結果為:
$ scalac Test.scala $ scala Test x 的坐標點: 20 y 的坐標點: 30
Scala 繼承
Scala繼承一個基類跟Java很相似, 但我們需要注意以下幾點:
- 1、重寫一個非抽象方法必須使用override修飾符。
- 2、隻有主構造函數才可以往基類的構造函數裏寫參數。
- 3、在子類中重寫超類的抽象方法時,你不需要使用override關鍵字。
接下來讓我們來看個實例:
實例
var x: Int = xc
var y: Int = yc
def move(dx: Int, dy: Int) {
x = x + dx
y = y + dy
println ("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 = zc
def move(dx: Int, dy: Int, dz: Int) {
x = x + dx
y = y + dy
z = z + dz
println ("x 的坐標點 : " + x);
println ("y 的坐標點 : " + y);
println ("z 的坐標點 : " + z);
}
}
Scala 使用 extends 關鍵字來繼承一個類。實例中 Location 類繼承了 Point 類。Point 稱為父類(基類),Location 稱為子類。
override val xc 為重寫了父類的字段。
繼承會繼承父類的所有屬性和方法,Scala 隻允許繼承一個父類。
實例如下:
實例
class Point(val xc: Int, val yc: Int) {
var x: Int = xc
var y: Int = yc
def move(dx: Int, dy: Int) {
x = x + dx
y = y + dy
println ("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 = zc
def move(dx: Int, dy: Int, dz: Int) {
x = x + dx
y = y + dy
z = z + dz
println ("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);
}
}
執行以上代碼,輸出結果為:
$ scalac Test.scala $ scala Test x 的坐標點 : 20 y 的坐標點 : 30 z 的坐標點 : 20
Scala重寫一個非抽象方法,必須用override修飾符。
實例
var name = ""
override def toString = getClass.getName + "[name=" + name + "]"
}
class Employee extends Person {
var salary = 0.0
override def toString = super.toString + "[salary=" + salary + "]"
}
object Test extends App {
val fred = new Employee
fred.name = "Fred"
fred.salary = 50000
println(fred)
}
執行以上代碼,輸出結果為:
$ scalac Test.scala $ scala Test Employee[name=Fred][salary=50000.0]
Scala 單例對象
在 Scala 中,是沒有 static 這個東西的,但是它也為我們提供了單例模式的實現方法,那就是使用關鍵字 object。
Scala 中使用單例模式時,除了定義的類之外,還要定義一個同名的 object 對象,它和類的區別是,object對象不能帶參數。
當單例對象與某個類共享同一個名稱時,他被稱作是這個類的伴生對象:companion object。你必須在同一個源文件裏定義類和它的伴生對象。類被稱為是這個單例對象的伴生類:companion class。類和它的伴生對象可以互相訪問其私有成員。
單例對象實例
實例
class Point(val xc: Int, val yc: Int) {
var x: Int = xc
var y: Int = yc
def move(dx: Int, dy: Int) {
x = x + dx
y = y + dy
}
}
object Test {
def main(args: Array[String]) {
val point = new Point(10, 20)
printPoint
def printPoint{
println ("x 的坐標點 : " + point.x);
println ("y 的坐標點 : " + point.y);
}
}
}
執行以上代碼,輸出結果為:
$ scalac Test.scala $ scala Test x 的坐標點 : 10 y 的坐標點 : 20
伴生對象實例
實例
* author:菜鳥教程
* url:rb.wikimirror.xyz
*/
// 私有構造方法
class Marker private(val color:String) {
println("創建" + this)
override def toString(): String = "顏色標記:"+ color
}
// 伴生對象,與類名字相同,可以訪問類的私有屬性和方法
object Marker{
private val markers: Map[String, Marker] = Map(
"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"))
// 單例函數調用,省略了.(點)符號
println(Marker getMarker "blue")
}
}
執行以上代碼,輸出結果為:
$ scalac Marker.scala $ scala Marker 創建顏色標記:red 創建顏色標記:blue 創建顏色標記:green 顏色標記:red 顏色標記:blue
點我分享筆記