定向和访问成员变量

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()


}

}
相关推荐
智海观潮3 天前
学好Spark必须要掌握的Scala技术点
大数据·spark·scala
盛小夏4 天前
用链式风格写代码,就像在搭积木
scala
盛小夏6 天前
元组(Tuple)详解:初学者必须掌握的数据结构
scala
赞鱼儿7 天前
Scala中函数的基本使用
scala
还是大剑师兰特8 天前
Scala面试题及详细答案100道(71-80)-- 与Java的交互
scala·大剑师·scala面试题
92749 天前
12函数参数
scala
geilip13 天前
知识体系_scala_利用scala和spark构建数据应用
开发语言·spark·scala
Hello.Reader13 天前
Flink 高级配置发行版剖析、Scala 版本、Table 依赖与 Hadoop 集成实战
hadoop·flink·scala
IvanCodes17 天前
八、Scala 集合与函数式编程
大数据·开发语言·scala
卓码软件测评18 天前
第三方软件测试公司:【Gatling基于Scala的开源高性能负载测试工具】
测试工具·开源·scala·压力测试·可用性测试·第三方软件测试