列表
使用List("","","")去声明
sliding 和 groued表示迭代器
bash
val iter = List("Hadoop", "Spark", "Scala") sliding 2
// sliding 和 groued 是有区别的
while (iter.hasNext){
println(iter.next())
}
for (elem <- iter){
println(elem)
}
可变数组
bash
def main(args: Array[String]): Unit = {
import scala.collection.mutable.ArrayBuffer
val aMutableArr = ArrayBuffer(10,20,30)
println(aMutableArr)
aMutableArr += 40
println(aMutableArr)
aMutableArr.insert(2,60)
println(aMutableArr)
aMutableArr -= 40
println(aMutableArr)
}
元组
bash
def main(args: Array[String]): Unit = {
val tuple = ("Bigdata",2022,45.0)
println(tuple)
println(tuple._1)
println(tuple._2)
}
构造器
bash
class Counter{
private var value = 0 // value用来储存计数器的起始值
private var name = "" //表示计数器的名称
private var mode = 1 // mode用来表示计数器的类型(比如,1表示部署计数器,2表示时间计数器
def this(name: String){ // 第一个辅助计数器
this() // 调用主构造器
this.name = name
}
def this(name: String,mode:Int){// 第二个辅助构造器
this(name) // 调用前一个辅助构造器
this.mode = mode
}
def increment(step: Int):Unit = {value += step}
def current():Int = {value}
def info():Unit = {printf("name:%s and mode is %d\n",name,mode)}
}
object Main {
def main(args: Array[String]): Unit = {
val myCounter = new Counter // 主构造器
val counter1 = new Counter("Runner")
val counter2 = new Counter("Timer",2)
myCounter.info() // 显示计数器信息
myCounter.increment(1) // 设置步长
println(myCounter.current)
counter1.info()
counter1.increment(2)
println(counter1.current)
counter2.info()
counter2.increment(3)
println(counter2.current)
}
}
- 构造器在参数中
bash
class Counter(val name:String = "",val mode:Int = 1){
private var value = 0 // value用来储存计数器的起始值
def increment(step: Int):Unit = {value += step}
def current():Int = {value}
def info():Unit = {printf("name:%s and mode is %d\n",name,mode)}
}
object Main {
def main(args: Array[String]): Unit = {
val myCounter = new Counter // 主构造器
val counter1 = new Counter("Runner")
val counter2 = new Counter("Timer",2)
myCounter.info() // 显示计数器信息
myCounter.increment(1) // 设置步长
println(myCounter.current)
counter1.info()
counter1.increment(2)
println(counter1.current)
counter2.info()
counter2.increment(3)
println(counter2.current)
}
}
单例对象
Scala并没有提供Java那样的静态方法和静态字段,但是可以采用object关键字实现单例对象,具备和Java静态方法相同的功能。
bash
object Person{
private var lastId = 0 // 身份证号
def nerPersonId()={
lastId += 1
lastId
}
}
伴生类和伴生对象
bash
class Person{
private val id = Person.newPersonId() // 调用了伴生对象中的方法
private var name = ""
def this(name: String){
this()
this.name = name
}
def info() {printf("the id of %s is %d.\n",name,id)}
}
object Person{
private var lastId = 0 // 身份证号
def newPersonId()={
lastId += 1
lastId
}
}
object Main {
def main(args: Array[String]): Unit = {
val person1 = new Person("ziyu")
val person2 = new Person("Minxing")
person1.info()
person2.info()
}
}
apply方法和update方法
- 我们经常会用到对象的apply方法和update方法,虽然我们表面上并没有察觉,但是实际上,在Scala中,apply方法和update方法都会遵循相关的约定被调用
- apply方法:用括号传递给变量(对象)一个或多个参数时,Scala会把它转换成对apply方法的调用
bash
class TestApplyclass{
def apply(param:String):String = {
println(param)
return "hello world"
}
}
object Main {
def main(args: Array[String]): Unit = {
val myObject = new TestApplyclass
println(myObject("param1"))
}
}
这种方式生成对象 会自动调用apply方法
bash
class Main{}
class ApplyTest{
def apply() = println("apply method id class is called!")
def greetingOfclass():Unit = {
println("Greeting method in class is called.")
}
}
object ApplyTest{
def apply() = {
println("apply method in object is called")
new ApplyTest() // 这行不会自动调用ApplyTest伴生类的apply方法
}
}
object Main {
def main(args: Array[String]): Unit = {
val a = ApplyTest() // 这里会调用伴生对象中的apply方法
a.greetingOfclass()
a() // 这里会调用半生类中的apply方法
}
}
- update方法:当对带有括号并包括一到若干参数的对象进行赋值时,编译器将调用对象的update方法,在调用时,是把括号里的参数和等号右边的对象一起作为update方法的输入参数来执行调用
抽象类和继承
bash
abstract class Car{
val carBrand: String
def info
def greeting() {println("welcome to my car!")}
}
class BMWCar extends Car{
override val carBrand: String = "BMW"
def info(){println(this.carBrand)}
override def greeting(){println("welcome to BMW car!")}
}
特质
特质概述
- Java中提供了接口,允许一个类实现任意数量的接口
- 在Scala中没有接口的概念,二十提供了"特质(trait)",它不仅实现了接口的功能,还具备了很多其他的特性
- Scala的特质,是代码重用的基本单元,可以同时拥有抽象方法和具体方法
- Scala中,一个类只能继承自一个超类,却可以实现多个特质,从而重用特质中的方法和字段,实现了多重继承
bash
trait CarId{
var id:Int
def currentId():Int //定义了一个抽象方法
}
class BYDCarId extends CarId{
override var id = 10000 // BYD汽车编号从10000开始
def currentId():Int = {id += 1;id}
}
class BMWCarId extends CarId{
override var id = 20000 // BMW汽车编号从20000开始
def currentId():Int = {id += 1;id}
}