mak*_*enz 5 scala pattern-matching
我需要在Classes上进行模式匹配.问题是,我有一些匹配Long的问题.
我需要以相同的方式处理scala.Long和java.lang.Long,但为什么我需要在两种情况下声明它们?
这是一个例子:
def test(typ: Class[_]) {
typ match {
case q if q == classOf[Long] => println("scala long...")
}
}
val scalaLongField: java.reflect.Field = ......
val javaLongField: java.reflect.Field = ......
test(scalaLongField.getType) // prints "scala long..."
test(javaLongField.getType) // scala.MatchError: class java.lang.Long (of class java.lang.Class)
Run Code Online (Sandbox Code Playgroud)
有没有办法处理它们没有实例而只有类?
原因是java.lang.Long和Long是不同的类。java.lang.Long.class在Java中,和之间是有区别的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());
}
}
Run Code Online (Sandbox Code Playgroud)
一般来说,您必须分别对待classOf[Long]和classOf[java.lang.Long]。也许,如果您描述需要如何处理它们,我们可以为您的特定任务找到更好的解决方案。
| 归档时间: |
|
| 查看次数: |
4062 次 |
| 最近记录: |