Scala 类的构造方法

本文介绍了Scala中的构造方法,包括主构造器和辅助构造器的概念。主构造器与类定义紧密相关,辅助构造器则通过this调用来实现。在Scala中,每个类只有一个主构造器,而辅助构造器提供了更多构造形式。与Java不同,Java没有主辅助构造器之分,只有默认无参和有参构造器,而Scala的构造器名称为this,与Java有所区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

scala的构造,分为主构造器和辅助构造器

主构造器的定义和类的定义交织在一起
定义一个主构造器

class Xxx(参数列表) {
}

类名后面的内容就是主构造器,
如果参数列表为空的话,()可以省略
scala的类有且仅有一个主构造器,要想提供更加丰富的构造器,就需要使用辅助构造器

辅助构造器

def this(参数列表)

scala中的辅助构造器,在函数体的第一行
必须以调用其它辅助构造器或者主构造器开始

也就是说要使用this(参数列表)去调用其它构造器
suoyoshuo一个辅助构造器最终还是要从主构造器的调用开始

scala和java的构造器的区别

java的构造器没有主构造器和辅助构造器之分
只分为默认的无参构造器和有参构造器
scala中默认的构造器就是类名后面的构造器
称之为主构造器,同时还拥有辅助构造器
java的构造器名称和类名一样
scala中的构造器名称就是this,其余和java一样

class Student(n:String, a:Int) {

private var name:String = _
private var age:Int = _

def Student(name:String, age:Int): Unit = {
    this.name = name
    this.age = age
}
//辅助构造器
def this() {
    this("张三", 28)
    println("---辅助构造器def this()-----")
}

def this(age:Int) {
    this()
    this.age = age
    println("---辅助构造器def this
### Scala 的定义和使用 #### 定义Scala 中,可以通过 `class` 关键字来定义。与 Java 不同的是,默认情况下所有的成员都是公有的,并且不需要显式的访问修饰符。 ```scala // 定义一个简单的 Person class Person(val name: String, var age: Int) { def greet(): Unit = println(s"Hello, my name is $name and I am $age years old.") } ``` 这里定义了一个名为 `Person` 的,它有两个字段:`name` 和 `age`。其中 `val` 表明这个属性是不可变的,而 `var` 则表示可变属性。还定义了一个方法 `greet()` 来打印一条问候消息[^1]。 #### 构造器 Scala 支持主构造器和辅助构造器的概念。上面的例子中已经展示了主构造器的应用方式——直接放在头后面的参数列表即为主构造器的一部分。如果需要更多的初始化逻辑,则可以在大括号内编写相应的代码。 对于辅助构造器来说,可以利用 `this` 关键字创建多个重载版本: ```scala class Student(name: String, age: Int, val grade: Char) extends Person(name, age){ // 辅助构造器 def this(name: String, age: Int){ this(name, age,'A') // 调用了主构造器 } override def greet(): Unit ={ super.greet() println(s"I'm studying in Grade ${grade}.") } } ``` 这段代码展示了一个继承自 `Person` 的子 `Student`,并实现了自己的辅助构造器以及覆写了父的方法 `greet()`。 #### 使用 一旦定义好了之后就可以实例化对象了。这通常只需要简单地提供必要的参数给构造器即可完成操作。 ```scala val person = new Person("Alice", 30) person.greet() val student = new Student("Bob", 20, 'B') student.greet() ``` 上述两行分别创建了 `Person` 及其派生出来的 `Student` 实例,并调用了它们各自的 `greet()` 方法。 #### 抽象 当某些功能无法具体实现时,可以选择将其声明为抽象函数或抽象。这样做的好处是可以强制任何具体的子都必须给出这些未实现部分的具体实现形式。 ```scala abstract class AbstractAdd { def add(x: Int, y: Int): Int // 抽象方法 } class ConcreteAdd extends AbstractAdd { override def add(x: Int, y: Int): Int = x + y // 子提供了具体实现 } ``` 在这个例子中,`AbstractAdd` 是一个带有抽象方法 `add` 的抽象;而 `ConcreteAdd` 继承自前者并且给出了实际的操作细节[^4]。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值