定向和访问成员变量

1. 辅助构造器通过 constructor 关键字定义

  1. 必须在辅助构造器内部调用主构造器(直接或间接通过其他辅助构造器)
  2. 一个类可以有多个辅助构造器,以适应不同的对象创建场景
  • 构造器的默认值
  • 必填项: 姓名, 年龄,
  • 有默认值的项
  • 性别:男
  • 民族:汉
scala 复制代码
object Base15 {
  
  class Student(var name: String, var age: Int, var gender: String = "男", var nav: String = "汉族") {

    def say(): Unit = {
      println(s"${name}, ${age}, ${gender}, ${nav}")
    }
  }

  def main (args: Array [String]): Unit
  =
  {
    // var s0 = new Student() // gender 和 nav 使用默认值
    var s1 =new Student("小明", 19) // gender 和 nav 使用默认值
    s1.say()

    var s2 =new Student("小花", 18, "女", "回族")
    s2.say()
  }
}
    • // 辅助构造器
  • // 名称一定是 this
  • // 在辅助构造器内部,一定要调用主构造器 this
  • // 可以有多个
scala 复制代码
object Base17 {
// 多种注册用户的方式 ---- 辅助构造器
// 1. 手机号 + 密码
// 2. 邮箱 + 密码 + 用户名
// 姓名class Register (val name: String, var email: String, var pwd: String, var phone: String) {

println ("主构造器被调用")

def this (phone: String, pwd: String) {
this ("随机用户 xxxxx", "xxxx@qq.com", pwd, phone)
// 调用主构造器
println ("辅助构造器被调用")}

def this (email: String, pwd: String, name: String) {this (name, email, pwd, "13600000000") 
// 调用主构造器
println ("辅助构造器被调用")}

def say (): Unit = {
println (s" 姓名: ${name},邮箱: ${email}, 密码: ${pwd}, 手机号: ${phone}")}
}

def main (args: Array [String]): Unit = {
//val r1 = new Register ("小明", "123123@qq.com", "123456", "13617885566")
// 调用辅助构造器
val r1 = new Register ("13617885566", "123456")
val r2 = new Register ("9456651@qq.com", "123456", "小明")

r1.say()
r2.say()


}

}
相关推荐
IvanCodes2 天前
七、Scala 包、样例类与样例对象
大数据·开发语言·scala
浩浩kids2 天前
Scala • basis
java·开发语言·scala
Java水解10 天前
Scala深入面向对象:类、对象与伴生关系
后端·scala
哈哈很哈哈14 天前
Spark 核心 RDD详解
大数据·分布式·spark·scala
DTS小夏14 天前
Linux 系统 + IDEA+Scala 插件:新手进阶开发指南
linux·scala·intellij-idea
渣渣盟16 天前
Spark核心:单跳转换率计算全解析
大数据·spark·scala·apache
闯闯桑17 天前
Spark 中spark.implicits._ 中的 toDF和DataFrame 类本身的 toDF 方法
大数据·ajax·spark·scala
MOMO陌染19 天前
IDEA环境搭建与输出
scala
闯闯桑21 天前
toDF(columns: _*) 语法
开发语言·前端·spark·scala·apache