val study = Study("tiger")
// 普通方法
// study.myPrintln()
// is + as 转换
// is + as = 一般是配合在一起使用的
println(study is Person)
println(study is Study)
if (study is Person){ // 在这里,子类也重写了父类,会输出一次子类的调用
(study as Person).myPrintln()
}
if (study is Study){
(study as Study).myPrintln()
}
// kotlin 中所有的类,默认是 final 修饰的,是不能被继承的,和Java 相反
// open 移除final 修饰符
open class Person(private val name: String){
private fun showName() = "父类 的姓名是:$name"
// 父类需要被子类继承的方法
open fun myPrintln() = println(showName())
}
class Study(private val subName: String) : Person(subName){
private fun showName() = "子类 的姓名是:$subName"
override fun myPrintln() {
super.myPrintln()
println("我是继承自父类的方法: ${showName()}")
}
}
3、Any 超类
// 在kotlin 中,所有的类都隐式继承了 :Any() 你不写,默认就有
// Any 类在kotlin 设计中,只提供标准,你看不到实现,实现在各个平台实现就好了
class Person : Any()
// 匿名对象, object : 表达式
val p = object : Person(){
override fun add(name: String) {
super.add(name)
}
override fun del(name: String) {
super.del(name)
}
}
p.add("tiger")
p.del("张三")
// 具名的实现方式
val p2 = Person()
p2.add("王五")
p2.del("刘美丽")
open class Person(){
open fun add(name: String) = println("新增: $name")
open fun del(name: String) = println("删除: $name")
}
6、伴生对象
println(Study.name)
Study.showInfo()
class Study{
// 伴生对象
companion object {
val name = "张三"
fun showInfo() = println("学生:$name")
}
}
7、嵌套类和内部类
// 内部类的访问
Person(18).Study("tiger").getName()
// 嵌套类的调用
Body().showInfo()
// 内部类的特点:外部类,能访问内部类,内部类能访问外部类
class Person(val age: Int){
// 默认情况下,内部类不能访问外部类,要增加修饰符 inner 才能够访问外部内
inner class Study(val name: String){
fun getName() = println("这个学生叫:$name 年龄:$age")
}
}
// 嵌套类: kotlin 默认情况下,就是一个嵌套类
// 外部的类,能访问嵌套的内部类,嵌套的内部类不能访问外部的类
class Body{
val info = "tiger"
fun showInfo() = Heart(info).showIfo()
class Heart(val info: String){
fun showIfo() = println("我就是个测试 $info")
}
}
8、数据类
// 普通类
// 普通类只会生成 set get 构造函数
class ResponseResultBean(val name: String, val age: Int)
// 数据类
// 数据类 会生成 set get 构造函数 copy toString hashCode equals
data class ResponseResultBean1(val name: String, val age: Int)