原因是java.lang.Long
和Long
是不同的类。在 Java 中, 和 是有区别java.lang.Long.class
的Long.TYPE
。同样,在 Scala 中,classOf[Long]
又classOf[java.lang.Long]
是不同的。
如果要对类进行模式匹配,可以为此创建辅助unapply
方法:
object ScalaLong {
// Internal helper:
private def matchClass[T](c: Class[_], as: Class[T]): Option[Class[T]] =
if (as.isAssignableFrom(c)) Some(as)
else None;
// Matches wrapped Long classes.
object LongObject {
def unapply(c: Class[_]): Option[Class[java.lang.Long]] =
matchClass(c, classOf[java.lang.Long]);
}
// Matches primitive long classes.
object LongPrim {
def unapply(c: Class[_]): Option[Class[Long]] =
matchClass(c, classOf[Long]);
}
// -- Test:
def check(clz: Class[_]) =
clz match {
case LongPrim(c) => println("Long primitive: " + c);
case LongObject(c) => println("Long object: " + c);
case _ => println("Other: " + clz);
}
class Example {
val l1: scala.Long = 1L;
val l2: java.lang.Long = 1L;
val l3: java.lang.Integer = 1;
}
def main(argv: Array[String]) {
for(name <- Seq("l1", "l2", "l3"))
check(classOf[Example].getMethod(name).getReturnType());
}
}
classOf[Long]
一般来说,你必须classOf[java.lang.Long]
分开治疗。也许,如果您描述了您需要对它们做什么,我们可以为您的特定任务找到更好的解决方案。