我可以将Int数据转换为Byte.
scala> 10.asInstanceOf[Byte]
res8: Byte = 10
Run Code Online (Sandbox Code Playgroud)
但是,如果使用任何类型的相同值,则转换会引发错误.
scala> val x : Any = 10
x: Any = 10
scala> x.asInstanceOf[Byte]
java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.Byte
at scala.runtime.BoxesRunTime.unboxToByte(BoxesRunTime.java:98)
at .<init>(<console>:10)
Run Code Online (Sandbox Code Playgroud)
我可以投两次.
scala> val y = x.asInstanceOf[Int]
y: Int = 10
scala> y.asInstanceOf[Byte]
res11: Byte = 10
Run Code Online (Sandbox Code Playgroud)
还有比这更好的方法吗?
在Scala中,编译器试图隐藏基本类型和引用类型(盒装)之间的区别,默认为基元.有时,抽象泄漏,你会看到那种问题.
在这里,您假装该值为Any,这需要编译器回退到盒装值:
override def set(value:Any) = {
if (check(value.asInstanceOf[Byte])) {
Run Code Online (Sandbox Code Playgroud)
在这里,你不是限制值作为参考,所以这样的转换将在原始类型上完成:
10.asInstanceOf[Byte]
Run Code Online (Sandbox Code Playgroud)
换一种说法:
scala> val x: Any = 10
x: Any = 10
scala> x.asInstanceOf[Byte]
java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.Byte
at scala.runtime.BoxesRunTime.unboxToByte(BoxesRunTime.java:97)
... 32 elided
scala> val y: Int = 10
y: Int = 10
scala> y.asInstanceOf[Byte]
res4: Byte = 10
Run Code Online (Sandbox Code Playgroud)
要解决这个问题,您可能需要进行额外的转换,比如String:
scala> x.toString.toInt
res6: Int = 10
scala> x.toString.toByte
res7: Byte = 10
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3201 次 |
| 最近记录: |