目录 1.扩展函数 2.infix 关键字 3.扩展函数文件 4.重命名扩展函数 1.扩展函数 1)当我们没法接触某个类的定义,或者某个类没有用open修饰无法继承时,我们可以通过扩展函数,来实现该
目录
- 1.扩展函数
- 2.infix 关键字
- 3.扩展函数文件
- 4.重命名扩展函数
1.扩展函数
1)当我们没法接触某个类的定义,或者某个类没有用open修饰无法继承时,我们可以通过扩展函数,来实现该类功能的扩展。扩展函数,可以扩展自定义类、String类以及kotlin标准库中的其他类。
2)定义扩展函数和定义一般函数差不多。唯一的不同就是,定义扩展函数时,除了函数定义外,还需指定给哪个类进行扩展。如:fun String.addExtention() = "Kotlin: ".plus(this) 这个就是给String类进行的功能扩展。
3)除了扩展函数外,还可以扩展属性。扩展属性和定义属性差不多,但是需要指定要扩展属性的类。也就是扩展属性功能的接收者。
val String.aCount
get() = count { "a".contains(it) }
4)我们还可以定义泛型类的扩展函数,来使扩展函数的功能更加强大。
//扩展String类的函数 fun String.addExtention() = "Kotlin: ".plus(this) fun String.easyPrint() = println(this) //扩展自定义类的函数 fun Apple.name() ="apple name "+this.name //扩展泛型函数 fun <T> T.easyPrintln() { println(this) } //扩展属性计算字符串"a"的个数 val String.aCount get() = count { "a".contains(it) } fun main() { val name = "HanMei" name.addExtention().easyPrint() val apple = Apple("apple") apple.name apple.easyPrintln() println(name.aCount) }
2.infix 关键字
用于定义单个参数的扩展函数。比如 to函数。
如果一个函数定义使用了infix关键字,那么调用这个函数时,调用者和函数直接的 "."和参数的一对括号,都可以省略。
这个to就是一个函数
val map = mapOf<Int,String>(1 to "hanmei")
public infix fun <A, B> A.to(that: B): Pair<A, B> = Pair(this, that)
可以看到to是一个泛型扩展函数。泛型<A,B> 调用者是A参数是B,返回值是Pair<A, B>
Pair(this, that) 这个就是函数定义,this代码函数调用者A,that 就是B
3.扩展函数文件
如果扩展函数需要在多个文件中使用,可以把这些扩展函数单独定义在一个文件中,然后import后使用。
扩展函数定义
package com.example.kotlin.gerneric //扩展String类的函数 public fun String.addExtention() = "Kotlin: ".plus(this)
扩展函数的使用
import com.example.kotlin.gerneric.addExtention fun main() { val name = "HanMei".addExtention() }
4.重命名扩展函数
如果想在使用时,想给扩展函数重写取一个名字,可以用as
import com.example.kotlin.gerneric.addExtention as addEX fun main() { val name = "HanMei".addEX() }
到此这篇关于Kotlin扩展函数超详细介绍的文章就介绍到这了,更多相关Kotlin扩展函数内容请搜索自由互联以前的文章或继续浏览下面的相关文章希望大家以后多多支持自由互联!