gpt4 book ai didi

kotlin - Kotlin 的固有 `areEqual` 方法的目的是什么?

转载 作者:行者123 更新时间:2023-12-02 13:05:33 25 4
gpt4 key购买 nike

假设我有一个

data class Eq(x: Int?)

这将生成一个看起来像这样的 equals 方法

public boolean equals(Object other){
if(this == other) return true;
if(!(other instanceof Eq)) return false;
Eq otherEq = (Eq) other;
return Intrinsics.areEqual(this.x, otherEq.x);
}

哪里是内在的

public static boolean areEqual(Object first, Object second){
return first == null ? second == null : first.equals(second);
}

我不太明白这背后的动机。

与内联其实现相比,保留静态调用有什么好处?

最佳答案

将内部方法保留为静态方法而不是在每个使用站点内联它有几个优点:

  • 它不会破坏生成的二进制文件。对于大多数内在函数,字节码中的方法调用比内联体要小。因此,内联函数会导致生成的二进制文件大小的增长。

  • 内在实现在语言演变过程中保持受控,并且在所有调用站点之间保持一致。由于内在函数作为一种方法保留,较新的运行时库可能会提供更好的实现,该实现将立即应用于所有调用站点,而不是内联具有不同版本的不同二进制文件。

至于为了性能而在编译时内联,在JVM的世界里,这通常是行不通的。 JVM 字节码是一个相当高级的抽象(堆栈机器码,与真实硬件相去甚远),并且 JVM 本身擅长在 JIT 编译期间内联方法调用,因此编译器通常不会运行微优化并依赖 JVM 实现中内置的优化。

关于kotlin - Kotlin 的固有 `areEqual` 方法的目的是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57254105/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com