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. 调用时可以省略 .(),让代码更流畅。
相关推荐
夜焱辰2 小时前
浏览器端 Agent 的文件版本管理:不用 Git,基于 OPFS + SQLite 自己造了一个
前端·人工智能
梦想的颜色2 小时前
TypeScript 完全指南(下):从类型体操到生产级配置
前端·javascript·typescript
赏金术士3 小时前
Android 项目模块化与 Feature 组件实践
android·kotlin·模块化
Hi~晴天大圣3 小时前
npm使用介绍
前端·npm·node.js
888CC++4 小时前
如何在 C 语言中进行程序调试?
前端·javascript·算法
喵个咪4 小时前
基于 Taro 的 Headless CMS 多端前端架构:技术解析与二次开发导引
前端·react.js·taro
狂炫冰美式5 小时前
你还在古法PPT吗,试试HTML呢?免费编辑导出工具给 xdm 放这了
前端·后端·github
万少5 小时前
未来组织的分水岭不是员工数量,而是人才密度
前端·后端·面试
任磊abc5 小时前
nextjs16配置eslint+prettier
前端·eslint·nextjs·prettier
x***r1515 小时前
Another-Redis-Desktop-Manager.1.3.7安装步骤详解(附Redis可视化连接与Key管理教程)
前端·bootstrap·html