Kotlin 标准函数 with、run、apply 的定义和使用

Kotlin 标准函数 withrunapply 的定义和使用

1. with 函数

定义

with 函数允许你在一个对象的上下文中执行一个 lambda 表达式,而不需要在 lambda 表达式中重复引用该对象。

|---|--------------------------------------------------------------------------------------|
| | @kotlin.internal.InlineOnly |
| | public inline fun <T, R> with(receiver: T, block: T.() -> R): R = receiver.block() |

使用场景

当你需要在多个地方引用同一个对象,并且不想每次都显式地写出这个对象名时,可以使用 with 函数。

示例

|---|------------------------------------------------|
| | val stringBuilder = StringBuilder() |
| | with(stringBuilder) { |
| | append("Hello") |
| | append(", ") |
| | append("World!") |
| | } |
| | println(stringBuilder) // 输出 "Hello, World!" |

2. run 函数

定义

run 是 Kotlin 中所有类的成员函数,用于在当前对象的上下文中执行一个 lambda 表达式,但不返回任何值(返回 Unit)。

虽然这不是显式定义的函数,但它是通过扩展函数为所有类隐式提供的。

使用场景

当你需要在对象的上下文中执行一些操作,但不需要返回任何结果时,可以使用 run

示例(虽然不常见,因为可以直接在对象上调用方法):

|---|------------------------------------------------|
| | val stringBuilder = StringBuilder() |
| | stringBuilder.run { |
| | append("Hello") |
| | append(", ") |
| | append("World!") |
| | } |
| | println(stringBuilder) // 输出 "Hello, World!" |

3. apply 函数

定义

apply 是 Kotlin 的一个扩展函数,它执行给定的 lambda 表达式,并返回调用它的对象本身。

|---|----------------------------------------------------------------------------------|
| | public inline fun <T> T.apply(block: T.() -> Unit): T { block(); return this } |

使用场景

当你需要在对象的上下文中执行一些操作,并希望返回该对象以便进行链式调用时,可以使用 apply

示例

复制代码

|---|------------------------------------------------|
| | val stringBuilder = StringBuilder().apply { |
| | append("Hello") |
| | append(", ") |
| | append("World!") |
| | } |
| | println(stringBuilder) // 输出 "Hello, World!" |

区别
  • with:接受一个对象和一个 lambda 表达式,在 lambda 表达式中可以直接调用该对象的方法,无需前缀。返回 lambda 表达式的返回值。
  • run:是类的成员函数,接受一个 lambda 表达式,在 lambda 表达式中可以直接调用该对象的方法。返回 Unit
  • apply:是扩展函数,接受一个 lambda 表达式,在 lambda 表达式中可以直接调用该对象的方法。返回调用它的对象本身。

定义静态方法

在 Kotlin 中,没有直接的"静态方法"概念,但你可以通过以下几种方式实现类似的功能:

  1. 顶层函数:在文件的顶层定义的函数可以在没有类实例的情况下调用。
复制代码

|---|--------------------------------------------------------------------------------------------|
| | // MyUtils.kt |
| | fun staticLikeFunction() { |
| | // ... |
| | } |
| | |
| | // 在其他文件中 |
| | MyUtilsKt.staticLikeFunction() // 注意:Kotlin 会为顶层函数生成一个包含文件名的类(除非你用 @file:JvmName 指定一个名称) |

  1. 对象表达式或对象声明:你可以创建一个单例对象,并在其中定义函数。

|---|-------------------------------------------|
| | object MyUtils { |
| | @JvmStatic // 如果你希望这个函数在 Java 中看起来像静态的 |
| | fun staticLikeFunction() { |
| | // ... |
| | } |
| | } |
| | |
| | // 调用 |
| | MyUtils.staticLikeFunction() |

相关推荐
GreenTea1 小时前
一文搞懂Harness Engineering与Meta-Harness
前端·人工智能·后端
killerbasd3 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
吴声子夜歌3 小时前
ES6——二进制数组详解
前端·ecmascript·es6
码事漫谈3 小时前
手把手带你部署本地模型,让你Token自由(小白专属)
前端·后端
ZC跨境爬虫3 小时前
【爬虫实战对比】Requests vs Scrapy 笔趣阁小说爬虫,从单线程到高效并发的全方位升级
前端·爬虫·scrapy·html
爱上好庆祝3 小时前
svg图片
前端·css·学习·html·css3
橘子编程4 小时前
JavaScript与TypeScript终极指南
javascript·ubuntu·typescript
王夏奇4 小时前
python中的__all__ 具体用法
java·前端·python
叫我一声阿雷吧4 小时前
JS 入门通关手册(45):浏览器渲染原理与重绘重排(性能优化核心,面试必考
javascript·前端面试·前端性能优化·浏览器渲染·浏览器渲染原理,重排重绘·reflow·repaint
大家的林语冰4 小时前
《前端周刊》尤大开源 Vite+ 全家桶,前端工业革命启动;尤大爆料 Void 云服务新产品,Vite 进军全栈开发;ECMA 源码映射规范......
前端·javascript·vue.js