Kotlin——面向对象编程

定义类

如果将open和abstract两个修饰符放在一起使用,编译器会发出警告,open是Kotlin新引入的修饰符,open是final的反义词,用于修饰一个类、方法、或属性,表明类可派生子类、方法或属性可被重写

一个Kotlin类可以有01个主构造器和0N个次构造器

中缀表达式

可以使用infix修饰方法,这样就表示中缀表达式------但是infix方法只能有一个参数

kotlin 复制代码
fun main() {
    var origin = Apple(2.4)
    var ap = origin add Apple(3.3)
    println(ap)
    origin drop Apple(1.1)
    println(ap)
}
class Apple(weight:Double){
    var weight = weight
    override fun toString(): String {
        return "Apple(weight=$weight)"
    }
    infix fun add(other:Apple):ApplePack{
        return ApplePack(this.weight+other.weight)
    }
    infix fun drop(other:Apple):ApplePack{
        return ApplePack(this.weight-other.weight)
    }

}
class ApplePack(weight: Double){
    var weight= weight
    override fun toString(): String {
        return "ApplePack(weight=$weight)"
    }

}

componentN方法与解构

Kotlin允许将一个对象的N个属性"解构"给多个变量,写法如下

如果希望将对象解构给多个变量,那么就必须为该对象的类定义componentN()方法。程序希望将对象解构给几个变量,就需要为该类定义几个componentN()方法,且该方法需要使用operator修饰

kotlin 复制代码
fun main() {
    var user = User("yeeku","668899",29)
    //将User对象解构给2个变量
    //只利用user对象的component1()和componet2()方法
    var (name,pass:String) =user
    println(name)
    println(pass)
    //将User对象解构给3个变量
    //利用user对象的component1()、component2()方法
    var(name2,pass2,age)=user
    println(name2)
    println(pass2)
    println(age)
}
class User(name: String ,pass:String,age:Int){
    var name=name
    var pass =pass
    var age = age
    //定义operator修饰的componentN方法,用于解构
    operator fun component1() :String{
        return this.name
    }
    operator fun component2() :String{
        return this.pass
    }
    operator fun component3() :Int{
        return this.age
    }
}

在某些时候程序希望解构的对象后面几个componentN()方法的返回值、忽略前几个componentN()方法的返回值、此时可通过下划线(_)来占位。例如如下代码

kotlin 复制代码
    var (_,pass3,age2)=user
    println(pass3)
    println(age2)

除此之外也可以使用这种解构的方法便利map

kotlin 复制代码
for((key,value) in map){
//使用key、value
}
相关推荐
白瓷梅子汤2 分钟前
跟着官方示例学习 @tanStack-form --- Linked Fields
前端·react.js
爱学习的茄子6 分钟前
深入理解JavaScript闭包:从入门到精通的实战指南
前端·javascript·面试
zhanshuo37 分钟前
不依赖框架,如何用 JS 实现一个完整的前端路由系统
前端·javascript·html
火柴盒zhang38 分钟前
websheet在线电子表格(spreadsheet)在集团型企业财务报表中的应用
前端·html·报表·合并·spreadsheet·websheet·集团财务
讨厌吃蛋黄酥38 分钟前
智能前端新纪元:语音交互技术与安全实践全解析
javascript
khalil40 分钟前
基于 Vue3实现一款简历生成工具
前端·vue.js
拾光拾趣录1 小时前
浏览器对队头阻塞问题的深度优化策略
前端·浏览器
用户8122199367221 小时前
[已完结]后端开发必备高阶技能--自研企业级网关组件(Netty+Nacos+Disruptor)
前端
万少1 小时前
2025中了 聊一聊程序员为什么都要做自己的产品
前端·harmonyos
1234Wu1 小时前
React Native 接入 eCharts
javascript·react native·react.js