Lor*_*hen 10 scala pattern-matching
我正在case x :: Nil => ...尝试确保列表是非空的,但它只匹配单个元素列表.如何使用模式匹配获取非空列表?
更新
我很抱歉,似乎我失去了一些东西,有一个特殊的场景使用匹配内部,
object AccountResult{
def unapply(account: AccountResult): Option[(String, List[String])] = ???
}
//ignore accountResult define please
accountResult match {
case AccountResult(_, x :: _) => ...
}
Run Code Online (Sandbox Code Playgroud)
如何匹配accountResult哪个List [String](x :: _)值不是Nil?然后获取匹配的List [String]值
Sha*_*nds 19
而不是仅指定空列表Nil,指定可以是任何列表的内容,例如:
case x :: tail => ... // tail is a local variable just like x, holding the tail of the list
Run Code Online (Sandbox Code Playgroud)
或者干脆:
case x :: _ => ...
Run Code Online (Sandbox Code Playgroud)
如果你不关心或不会使用尾巴.
这些模式将匹配具有至少一个元素的任何列表(而不是根据现有模式恰好一个元素).同样,模式:
case x :: y :: the_rest => ...
Run Code Online (Sandbox Code Playgroud)
将匹配任何列表至少包含两个元素.
编辑(回复您的评论):
您可以使用" @" 分配案例模式中的变量.因此,对于您可能已经看过的(典型用法)示例:
case acc@AccountResult(_, x :: tail) => ... // do something with 'acc'
Run Code Online (Sandbox Code Playgroud)
或者,根据您的评论匹配您正在寻找的用法:
case AccountResult(_, phone@(x :: tail)) => ... // do something with 'phone'
Run Code Online (Sandbox Code Playgroud)
Nya*_*vro 16
要检查列表是否为空,您可以通过以下方式匹配模式:
list match {
case Nil => false
case _ => true
}
Run Code Online (Sandbox Code Playgroud)
要么
list match {
case Nil => false
case x::xs => true
}
Run Code Online (Sandbox Code Playgroud)
如果您只想将整个非空列表分配给一个 val,而不拆分头和尾,您只需添加一个匹配空列表的案例,另一个将列表分配给一个变量名,如下所示:
accountResult match {
case List() => ??? // empty case
case myAccountResult => ??? //myAccountResult will contain the whole non-empty list
}
Run Code Online (Sandbox Code Playgroud)
Nil 也可以完成这项工作,匹配一个空列表
accountResult match {
case Nil => ??? // empty case
case myAccountResult => ??? //myAccountResult will contain the whole non-empty list
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
20118 次 |
| 最近记录: |