当前位置:  开发笔记 > 编程语言 > 正文

为什么scala在使用错误类型显然调用函数时返回Any(Val/Ref)

如何解决《为什么scala在使用错误类型显然调用函数时返回Any(Val/Ref)》经验,为你挑选了1个好方法。



1> maasg..:

这是工作中的Scala类型推断.在给定的例子,它试图找到共同的超类型StringInt,这是Any

考虑更深层次的层次结构:

trait Veggy
object tomato extends Veggy
trait Fruit extends Veggy
trait Orange extends Fruit
trait BloodOrange extends Orange
trait Apple extends Fruit

然后

unpack(Some(tomato), new Orange{}) // Veggy
unpack(Some(new Apple{}), new Orange{}) // Fruit
unpack(Some(new BloodOrange{}), new Orange{}) // Orange

您想确保两个参数的类型完全相同吗?然后你需要告诉编译器.

一种可能的方式是说xy每个有型,并且应该有证据表明,这两种类型是一样的:

def unpack[T,U <:T ](x:Option[T], y:U)(implicit ev: T =:= U) : T = x match { case Some(z) => z; case None => y }

unpack(Some(new Fruit{}), new Orange{})
:12: error: Cannot prove that Fruit =:= Orange.

unpack(Some(1), 2)  // Int = 1

推荐阅读
手机用户2402851155
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有