时间:2021-05-20
Kotlin的对象表达式与Java中的匿名内部类的主要区别:匿名内部类只能指定一个父类型,但对象表达式可以指定0~N个肤类型。
一、对象表达式
对象表达式的语法格式如下:
object [: 0~N个父类型]{ //对象表达式的类体部分}对象表达式还有如下规则:
输出结果:
<h1>随便输出点什么吧</h1>
<h2>随便输出点什么吧</h2>
<h3>随便输出点什么吧</h3>
<h4>随便输出点什么吧</h4>
<h5>随便输出点什么吧</h5>
<h6>随便输出点什么吧</h6>
-----------------------------------------------
初始化块
Kotlin
test方法
-----------------------------------------------
激光打印机
输出信息:Kotlin慢慢学
高速极光打印机们支持自动双面打印!
Kotlin的对象表达式可分为两种情形:
输出结果:
Kotlin
Java
Kotlin编译器可以识别private对象表达式的真实类型。
Kotlin的对象表达式可访问或修饰其作用域内的局部变量。
fun main(args: Array<String>) { var a = 20 var obj = object { fun change() { println("change()方法修改变量a的值") a++ } } obj.change() println(a)}输出结果:
change()方法修改变量a的值
21
Kotlin的对象表达式比Java的匿名内部类增强了三个方面:
二、对象声明和单例模式
对象声明的语法格式如下:
object ObjectName [: 0~N个父类型]{ //对象表达式的类体部分}对象声明与对象表达式的语法很相似,区别在于:对象表达式在object关键字后没有名字;而对象声明需要在object关键字后指定名字。
两者还有如下区别:
输出结果:
<h1>一起来学Kotlin</h1>
<h2>一起来学Kotlin</h2>
<h3>一起来学Kotlin</h3>
<h4>一起来学Kotlin</h4>
<h5>一起来学Kotlin</h5>
<h6>一起来学Kotlin</h6>
-----------------------------------------------
初始化块
Kotlin
test方法
-----------------------------------------------
激光打印机
输出信息:Kotlin真不错
高速极光打印机们支持自动双面打印!
对象声明专门用于实现单例模式,对象声明所定义的对象也就是该类的唯一实例,程序可通过对象声明的名称直接访问该类的唯一实例。
三、伴生对象和静态成员
在类中定义的对象声明,可使用companion修饰,这样该对象就变成了伴生对象。
每个类最多只能定义一个伴生对象,伴生对象相当于外部类的对象,程序可通过外部类直接调用伴生对象的成员。
package `0705`interface CompanionTest { fun output(msg: String)}class MyClass { //使用companion修饰的伴生对象 companion object MyObject1 : CompanionTest { val name = "name属性值" override fun output(msg: String) { for (i in 1..6) { println("<h${i}>${msg}</h${i}>") } } }}fun main(args: Array<String>) { //使用伴生对象所在的类调用伴生对象的方法 MyClass.output("Kotlin必须学") println(MyClass.name)}输出结果:
<h1>Kotlin必须学</h1>
<h2>Kotlin必须学</h2>
<h3>Kotlin必须学</h3>
<h4>Kotlin必须学</h4>
<h5>Kotlin必须学</h5>
<h6>Kotlin必须学</h6>
name属性值
伴生对象的主要作用就是为其所在的外部类模拟静态成员,但只是模拟,伴生对象的成员依然是伴生对象本身的实例成员,并不属于伴生对象所在的外部类。
四、伴生对象的扩展
伴生对象也可以被扩展。如果一个类具有伴生对象,则Kotlin允许为伴生对象扩展方法和属性。
package `0705`interface CompanionTest { fun output(msg: String)}class MyClass { //使用companion修饰的伴生对象 companion object : CompanionTest { val name = "name属性值" override fun output(msg: String) { for (i in 1..6) { println("<h${i}>${msg}</h${i}>") } } }}//为伴生对象扩展方法fun MyClass.Companion.test() { println("为伴生对象扩展的方法")}val MyClass.Companion.foo get() = "为伴生对象扩展的属性"fun main(args: Array<String>) { //使用伴生对象所在的类调用伴生对象的方法 MyClass.output("Kotlin必须学") println(MyClass.name) //通过伴生对象所在的类调用为伴生对象扩展的成员 MyClass.test() println(MyClass.foo)}输出结果:
<h1>Kotlin必须学</h1>
<h2>Kotlin必须学</h2>
<h3>Kotlin必须学</h3>
<h4>Kotlin必须学</h4>
<h5>Kotlin必须学</h5>
<h6>Kotlin必须学</h6>
name属性值
为伴生对象扩展的方法
为伴生对象扩展的属性
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前言object是Kotlin中的一个重要的关键字,也是Java中没有的。object主要有以下三种使用场景:对象声明(ObjectDeclaration)伴生
逆波兰表达式定义:传统的四则运算被称作是中缀表达式,即运算符实在两个运算对象之间的。逆波兰表达式被称作是后缀表达式,表达式实在运算对象的后面。逆波兰表达式:a+
正则表达式是一个对象,它描述了字符模式。JavaScript的RegExp类表示正则表达式和字符串和正则表达式定义,使用正则表达式来进行强大的模式匹配和搜索和替
JavaScript中的正则表达式解析正则表达式(regularexpression)对象包含一个正则表达式模式(pattern)。它具有用正则表达式模式去匹配
lambda表达式python中形如:lambdaparameters:expression称为lambda表达式,用于创建匿名函数,该表达式会产生一个函数对象