【发布时间】:2016-01-23 02:29:24
【问题描述】:
我有一个必须使用 Double 和 Float 的类。由于性能要求,我对(Double, Float) 使用带有@specialized 注释的泛型。我需要调用两个第三方函数。 ffunc(x: Float) 接受 Float,dfunc(y: Double) 接受 Double。在某些时候,我必须致电ffunc 或dfunc。为此,我使用 scala 模式匹配。我的代码如下所示:
class BoxingTest[@specialized(Double, Float) T] {
def foo(p: T): Unit = {
p match {
case dp: Double => dfunc(dp)
case df: Float => ffunc(df)
}
}
}
但是,scala 编译器为专用版本提供了未优化的字节码。当我查看专用类的字节码时,我看到了将我的专用类型转换为对象的非优化匹配代码。还有额外的装箱/拆箱如下:
41: invokestatic #21 // Method scala/runtime/BoxesRunTime.boxToDouble:(D)Ljava/lang/Double;
44: invokestatic #39 // Method scala/runtime/BoxesRunTime.unboxToDouble:(Ljava/lang/Object;)D
您能否建议将匹配代码替换为将被优化并避免装箱/拆箱的代码?
【问题讨论】:
标签: scala pattern-matching bytecode boxing specialized-annotation