加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

Scala提取器 – 跳过未使用的参数

发布时间:2020-12-16 19:07:34 所属栏目:安全 来源:网络整理
导读:给出以下代码: abstract class MyTuple... case class MySeptet(a: Int,b: Int,c: Int,d: Int,e: Int,f: Int,g: Int) extends MyTuplecase class MyOctet(a: Int,g: Int,h: Int) extends MyTuple... 当使用生成的提取器时,是否可以跳过剩余参数,假设它们未
给出以下代码:

abstract class MyTuple

... 

case class MySeptet(a: Int,b: Int,c: Int,d: Int,e: Int,f: Int,g: Int) extends MyTuple

case class MyOctet(a: Int,g: Int,h: Int) extends MyTuple

...

当使用生成的提取器时,是否可以跳过剩余参数,假设它们未被使用?

例如我不想在以下代码片段中写下大量的下划线:

case MyOctet(a,b,_,_) => ... // uses only a and b

解决方法

提供一些依赖于数组提取器的tuple类的提取器的简单方法,因此绕开了原始问题.

abstract class MyTuple (order: Int)
case class MySeptet(coord: Array[Int]) extends MyTuple(7)
case class MyOctet(coord: Array[Int]) extends MyTuple(8)

等等

val o = MyOctet( (1 to 8).toArray )

我们可以提取这样的八位字节中的前两个元素,

o match {
  case MyOctet( Array(a,_*) ) => a+b
  case _ => 0
}
res: Int = 3

请注意,这并不解决在上面定义的case类中跳过剩余参数的问题.

还要注意这种方法的弱点,如下所示,

scala> val Array(a,b) = Array(1)
scala.MatchError: [I@16a75c0 (of class [I)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读