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. 调用时可以省略 .(),让代码更流畅。
相关推荐
奇迹_h4 小时前
打造你的HTML5打地鼠游戏:零基础入门实践
前端
SuperEugene4 小时前
Vue生态精选篇:Element Plus 的“企业后台常用组件”用法扫盲
前端·vue.js·面试
Neptune14 小时前
JavaScript回归基本功之---类型判断--typeof篇
前端·javascript·面试
贾铭4 小时前
如何实现一个网页版的剪映(三)使用fabric.js绘制时间轴
前端·后端
子兮曰5 小时前
后端字段又改了?我撸了一个 BFF 数据适配器,从此再也不怕接口“屎山”!
前端·javascript·架构
万少7 小时前
使用Trae轻松安装openclaw的教程-附带免费token
前端·openai·ai编程
浪浪山_大橙子7 小时前
OpenClaw 十分钟快速,安装与接入完全指南 - 推荐使用trae 官方 skills 安装
前端·人工智能
忆江南7 小时前
iOS 可视化埋点与无痕埋点详解
前端
离开地球表面_997 小时前
金三银四程序员跳槽指南:从简历到面试再到 Offer 的全流程准备
前端·后端·面试
_柳青杨7 小时前
跨域获取 iframe 选中文本?自己写个代理中间层,再也不求后端!
前端