假设您创建了一个更高阶函数,该函数采用 () -> Unit 类型的lambda(没有参数,没有返回值),并执行它,如下所示:
fun nonInlined(block: () -> Unit) {
println("before")
block()
println("after")
}
用Java来说,这将转化为类似的东西(简化!):
public void nonInlined(Function block) {
System.out.println("before");
block.invoke();
System.out.println("after");
}
当你从Kotlin打电话时......
nonInlined {
println("do something here")
}
在引擎盖下,将在这里创建一个 Function 的实例,它将代码包装在lambda中(同样,这是简化的):
nonInlined(new Function() {
@Override
public void invoke() {
System.out.println("do something here");
}
});
所以基本上,调用这个函数并将lambda传递给它将始终创建一个 Function 对象的实例 .
另一方面,如果您使用 inline 关键字:
inline fun inlined(block: () -> Unit) {
println("before")
block()
println("after")
}
当你这样称呼时:
inlined {
println("do something here")
}
不会创建 Function 实例,相反,内联函数内的 block 调用周围的代码将被复制到调用站点,因此您将在字节码中得到类似的内容:
System.out.println("before");
System.out.println("do something here");
System.out.println("after");
在这种情况下,不会创建新实例 .