Kotlin infix函数用法详解

什么是 infix 函数?

infix 关键字可以让 单参数的函数更自然的语法 书写,使代码更易读。 你可以把它理解为 一种特殊的调用方式 ,不需要 .(),让代码像 自然语言 一样流畅。

要使用 infix,需要满足 三个条件

  1. 必须是成员函数或扩展函数(它必须属于某个类或某种类型)。
  2. 必须只有且只能有一个参数 (如果有多个参数,就不能用 infix)。
  3. ⭐⭐⭐⭐⭐⭐调用时可以省略 .() (但仍然可以用 . 调用)。

简单示例 1:数字比较

不使用 infix

kotlin 复制代码
fun isBigger(a: Int, b: Int): Boolean {
    return a > b
}

fun main() {
    println(isBigger(10, 5)) // 输出:true
}

这个函数 isBigger(10, 5) 可读性一般,我们可以用 infix 改写它。


使用 infix

kotlin 复制代码
infix fun Int.isBiggerThan(other: Int): Boolean {
    return this > other
}

fun main() {
    println(10 isBiggerThan 5) // 输出:true
}

10 isBiggerThan 5 读起来就像 自然语言 ,比 isBigger(10, 5) 更易懂。


简单示例 2:创建 "名字-值" 对

普通方式

kotlin 复制代码
fun pair(key: String, value: String): Pair<String, String> {
    return Pair(key, value)
}

fun main() {
    val result = pair("name", "Alice")
    println(result) // 输出: (name, Alice)
}

使用 infix

kotlin 复制代码
infix fun String.with(value: String): Pair<String, String> {
    return Pair(this, value)
}

fun main() {
    val result = "name" with "Alice"
    println(result) // 输出: (name, Alice)
}

"name" with "Alice" 读起来更像 自然语言 ,比 pair("name", "Alice") 更直观。


简单示例 3:自定义数学运算

普通加法

kotlin 复制代码
class Point(val x: Int, val y: Int) {
    fun add(other: Point): Point {
        return Point(this.x + other.x, this.y + other.y)
    }
}

fun main() {
    val p1 = Point(2, 3)
    val p2 = Point(4, 5)
    val result = p1.add(p2)

    println("(${result.x}, ${result.y})") // 输出:(6, 8)
}

使用 infix

kotlin 复制代码
class Point(val x: Int, val y: Int) {
    infix fun add(other: Point): Point {
        return Point(this.x + other.x, this.y + other.y)
    }
}

fun main() {
    val p1 = Point(2, 3)
    val p2 = Point(4, 5)
    val result = p1 add p2  // 👈 重点:不需要 `.` 和 `()` 了!

    println("(${result.x}, ${result.y})") // 输出:(6, 8)
}

p1 add p2 p1.add(p2) 更像数学公式,可读性更强。

错误示范

kotlin 复制代码
class Point(val x: Int, val y: Int) {
    infix fun Point.add(other: Point): Point { //和正确例子唯一差别就是这一行
        return Point(this.x + other.x, this.y + other.y)
    }
}

fun main() {
    val p1 = Point(2, 3)
    val p2 = Point(4, 5)
    val result = p1 add p2  // 👈 重点:不需要 . 和 () 了!

    println("(${result.x}, ${result.y})") // 输出:(6, 8)
}

不能编译 ,是因为 infix 函数不能在类内部对自身类型(Point)扩展


总结

  1. infix 让代码更像自然语言,增强可读性
  2. 只能用于
    • 类的成员函数 (如 Point 里的 add)。
    • 扩展函数 (如 String.with())。
    • 且只接受一个参数
  3. 调用时可以省略 .(),让代码更流畅。
相关推荐
wuhen_n4 小时前
JavaScript内置数据结构
开发语言·前端·javascript·数据结构
大鱼前端4 小时前
为什么我说CSS-in-JS是前端“最佳”的糟粕设计?
前端
不爱吃糖的程序媛4 小时前
Capacitor:跨平台Web原生应用开发利器,现已全面适配鸿蒙
前端·华为·harmonyos
AC赳赳老秦4 小时前
2026国产算力新周期:DeepSeek实战适配英伟达H200,引领大模型训练效率跃升
大数据·前端·人工智能·算法·tidb·memcache·deepseek
CHU7290354 小时前
淘宝扭蛋机抽盒小程序前端功能解析:解锁趣味抽盒新体验
前端·小程序
儿歌八万首4 小时前
硬核春节:用 Compose 打造“赛博鞭炮”
android·kotlin·compose·春节
-凌凌漆-4 小时前
【npm】npm的-D选项介绍
前端·npm·node.js
鹿心肺语5 小时前
前端HTML转PDF的两种主流方案深度解析
前端·javascript
海石5 小时前
去到比北方更北的地方—2025年终总结
前端·ai编程·年终总结
一个懒人懒人5 小时前
Promise async/await与fetch的概念
前端·javascript·html