Scala 类和对象
类是对象的抽象,而对象是类的具体实例。类是抽象的,不占用内存,而对象是具体的,占用存储空间。类是用于创建对象的蓝图,它是一个定义包括在特定类型的对象中的方法和变量的软件模板。
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);
}
}
Scala中的类不声明为public,一个Scala源文件中可以有多个类。
以上实例的类定义了两个变量 x 和 y ,一个方法:move,方法没有返回值。
Scala 的类定义可以有参数,称为类参数,如上面的 xc, yc,类参数在整个类中都可以访问。
接着我们可以使用 new 来实例化类,并访问类中的方法和变量:
import java.io._
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伴生类和伴生对象
单例对象与类同名时,这个单例对象被称为这个类的伴生对象,而这个类被称为这个单例对象的伴生类。伴生类和伴生对象要在同一个源文件中定义,伴生对象和伴生类可以互相访问其私有成员。不与伴生类同名的单例对象称为孤立对象。
1、什么是伴生对象
scala中的类不能定义静态成员,而代之以定义单例对象来替代
单例对象通过object关键字来声明
单例对象中的所有方法,可以直接通过object单例对象的名字直接来调用。
一个单例对象可以绑定在一个类,当单例对象和某个类写在同一个源文件且共享一个名字,它们就产生了绑定关系。
此时单例对象称之为该类的伴生对象,类称之为该对象的伴生类。
object food {
def getFood(){
println("this is not the same")
}
}
class food{
def getFood(): Unit ={
println("this is your food.")
}
}
2、伴生对象与伴生类
类和它的伴生对象可以互相访问其私有成员
单例对象不能new,所以也没有构造参数
可以把单例对象当做java中可能会用到的静态方法工具类。
作为程序入口的方法必须是静态的,所以main方法必须处在一个单例对象中,而不能写在一个类中。
3、单例对象在第一次被访问时才会被初始化,来自于scala自带的predef包。
方法与函数
Scala 中的方法跟 Java 的方法一样,方法是组成类的一部分。方法有名字、类型签名,有时方法上还有注解,以及方法的功能实现代码(字节码)。
Scala 中的函数是一个完整的对象。可以赋值给一个变量,或者作为参数传给方法。
_,占位符
根据参数定义和上下文确定内容,相当偷懒,懒得抄变量名,也懒得起变量名。
Scala 变量(val、var)
在学习如何声明变量与常量之前,我们先来了解一些变量与常量。
- 一、变量: 在程序运行过程中其值可能发生改变的量叫做变量。如:时间,年龄。
- 二、常量 在程序运行过程中其值不会发生变化的量叫做常量。如:数值 3,字符'A'。
在 Scala 中,使用关键词 "var" 声明变量,使用关键词 "val" 声明常量。
声明实例如下:
var myVar : String = "variable" //变量
val myVal : String = "value" //常量
变量 ,我们可以修改它,(get和set都有)。
常量 ,它是不能修改的,(只有get没有set)。
Scala 集合api模拟WordCount
object ScalaWordCount {
def main(args: Array[String]): Unit = {
val lines = List("hello world","hello java java","hello scala scala scala","hello spark");
val words = lines.flatMap(_.split(" "));
println(s"words=$words");
val tuples = words.map((_, 1))
println(s"tuples=$tuples");
val groups = tuples.groupBy(_._1);
println(s"groups=$groups");
val sumed = groups.mapValues(_.size)
println(s"sumed=$sumed");
val sorted = sumed.toList.sortBy(_._2).reverse
print(s"sorted=$sorted");
}
}