千家信息网

每天学一点Scala之 伴生类和伴生对象

发表于:2025-01-25 作者:千家信息网编辑
千家信息网最后更新 2025年01月25日,1、 object 相当于class的单个实例,因此,在object里声明的变量都是静态变量,静态方法2、 在object里声明的变量,都是全局变量,也就是类的公共属性,或者类似于java中父类的属性
千家信息网最后更新 2025年01月25日每天学一点Scala之 伴生类和伴生对象

1、 object 相当于class的单个实例,因此,在object里声明的变量都是静态变量,静态方法

2、 object里声明的变量,都是全局变量,也就是类的公共属性,或者类似于java中父类的属性

3、 object里的构造器,也就是object 内部不在method中的代码,都属于构造器的内容

4、 同样,object的主构造器只会在第一次调用时执行,多次调用,只会执行一次。

  • object使用场景

1、 单例模式

2、 工具类

  • 伴生对象 伴生类?

如果有一个class,还有一个与class同名的object,那么就称这个objectclass的伴生对象,classobject的伴生类

  • 要求:

伴生类和伴生对象必须存放在一个.scala文件之中

特性?

//伴生对象、伴生类里的私有属性 跟 普通的私有属性 相比?
//伴生对象,伴生类里的私有属性的 使用范围,扩大了。
//伴生对象 与 伴生类可以互相访问彼此的私有属性,而普通私有属性仅仅只能在自己类里使用的

package com.xej.learning.objectLearning/**  * objectLearning 测试  */private[objectLearning] class Kafka(val name: String){     //目的:测试多次调用object时,其主构造方法调用几次   def sayHello(): Unit ={      objectTest.name      objectTest.name      objectTest.name      println("--------------------")   }}object objectTest {   val name = "spark"     println("----object----主构造器--------")     def main(args: Array[String]): Unit = {      new Kafka("spark").sayHello()   }}

执行结果如下:

----object----主构造器----------------------------

测试用例二:

package com.xej.learning.objectLearning/**  * 主要测试伴生对象,伴生类里的私有属性的访问范围  */private[objectLearning] class Student(val name: String, val age: Int, address: String="xizhimen"){     privateval sex = "male"   val weight = 80     def sayHello(): Unit ={      Student.address = address      //访问伴生对象里的普通属性 以及 私有属性      println("name:\t" + name + " ----> " + " age:\t" + age +         "\naddress:\t" + Student.address + " ----> school:\t" + Student.school)   }}object Student{   //伴生对象里的私有属性 跟 普通的私有属性 相比?   //伴生对象,伴生类里的私有属性的 使用范围,扩大了。   //伴生对象 与 伴生类可以互相访问彼此的私有属性,而普通私有属性仅仅只能在自己类里使用的   privateval school = "bjtu" //只能在伴生类里,调用,其他地方不能调用   var address = "beijing" //除了伴生类里,其他地方也可以调用,跟普通属性一样      //访问伴生类里的属性   val stu = new Student("lisi",22, "haidian")      println("----访问----伴生类里的---属性-----name:\t" + stu.name)   println("----访问----伴生类里的---私有属性-----sex:\t" + stu.sex)   println("----访问----伴生类里的---属性-----weight:\t" + stu.weight)}object objectTest2 {   def main(args: Array[String]): Unit = {      //调用伴生对象里的public属性      println("----address:\t" + Student.address)      //school是伴生对象的私有属性,这里不能访问的      //println("----school:\t" + Student.school)      new Student("zhansan", 19).sayHello()      new Student("xiaoming", 22,"haidian").sayHello()   }}

测试结果:

----访问----伴生类里的---属性-----name:        lisi----访问----伴生类里的---私有属性-----sex: male----访问----伴生类里的---属性-----weight:        80----address:    beijingname:   zhansan ---->  age:   19address:        xizhimen ----> school:     bjtuname:   xiaoming ---->  age:  22address:        haidian ----> school:      bjtuProcess finished with exit code 0

总之:

看到伴生对象,伴生类,要立马想到私有属性

伴生对象的使用场景,也就是说,伴生对象是干什么用的,这样的话,对于理解marathon源码,spark源码是有帮助的,不至于一头雾水。





0