如何使用默认参数为case类编写scala提取器?
发布时间:2020-12-16 18:11:44 所属栏目:安全 来源:网络整理
导读:我有以下case类和一个默认参数,我想知道如何编写一个unapply方法,以便我可以只提取前两个参数. 我希望下面的代码是清楚的. case class Point(x: Double,y: Double,_key: Option[String] = None) { def key: String = _key.getOrElse("")}object Point { def
我有以下case类和一个默认参数,我想知道如何编写一个unapply方法,以便我可以只提取前两个参数.
我希望下面的代码是清楚的. case class Point(x: Double,y: Double,_key: Option[String] = None) { def key: String = _key.getOrElse("") } object Point { def unapply(p: Point) = (p.x,p.y) } // pSeq is Seq[Point] pSeq.map { case Point(x,y) => x + y } // This causes a compiler error: // wrong number of arguments for <none>: // (x: Double,_key: Option[String]) 解决方法
我不确定这是否是您正在寻找的,但它会为您提供您描述的API.
sealed abstract class Point(x: Double,y: Double) case class PointKey(x: Double,_key: String) extends Point(x,y) case class PointNoKey(x: Double,y: Double) extends Point(x,y) object Point { def apply(x: Double,y: Double) = PointNoKey(x,y) def apply(x: Double,_key: String) = PointKey(x,y,_key) def unapply(p: Point): Option[(Double,Double)] = p match { case PointNoKey(x,y) => Some(x,y) case PointKey(x,_) => Some(x,y) } } 我认为只在案例类中使用通配符是首选,如果这对您有用. pSeq.map { case Point(x,_) => x + y } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |