1.private
object Class02 {
class Student(val name:String, val age:Int) {
private val hobbies:String = "躲在被子,打手电看恐怖小说"
private def hobby(): Unit = {
println(s"${hobbies}")
}
def sayHi():Unit = {
println(s"${name},${age}")
hobby()
}
}
def main(args:Array[String]): Unit = {
val stu = new Student("小花",18)
stu.sayHi()
}
}
2.判断类和对象的关系
object Class03 {
class Student(){}
class Teacher(){}
def main(args: Array[String]): Unit = {
val age:Int = 1
val stu = new Student()
println(stu.getClass)
println(age.getClass)
println(stu.isInstanceOf[Student])
println(stu.isInstanceOf[Teacher])
}
}
3.重写toString
object Class04 {
class Student(var name:String,var age:Int) {
override def toString: String = s"姓名: ${name}"
}
def main(args: Array[String]): Unit = {
val stu1 = new Student("小花",18)
val stu2 = new Student("小明",18)
println(stu1)
println(stu2)
}
}
4.判断两个对象是否相等
object Class05 {
class Student(val id:String,val name:String, val age:Int) {
override def equals(obj: Any): Boolean = {
println(s"比较是否相等...... ${this.id},${this.name},")
val other = obj.asInstanceOf[Student]
this.id == other.id && this.name == other.name
}
}
def main(args:Array[String]): Unit = {
val stu1 = new Student("20240010","小花",18)
val stu2 = new Student("20240010","小花",19)
if(stu1 == stu2){
println("他们是同一个人")
} else {
println("不是同一个人")
}
}
}
5.链式
object Class06 {
class Student() {
def sayHi():Student = {
println("sayhi")
this
}
def sayHello():Student = {
println("sayHello")
this
}
}
def main(args:Array[String]): Unit = {
val stu1 = new Student()
stu1.sayHi().sayHello()
}
}