scala匹配案例使用:: for lists

栏目: Scala · 发布时间: 5年前

内容简介:翻译自:https://stackoverflow.com/questions/8665580/scala-match-case-using-for-lists

鉴于此模式匹配:

List(1,2,3) match {
  case head :: tail => println(">>> head=" + head)
}

我假设’::’是在scala.collection.immutable中找到的case类,但是如何允许’::’以该形式写入(中缀表示法)? – 有一个特定的规则允许吗?

谢谢

你甚至可以写:

val head :: tail = List(1, 2, 3)

基本上任何预期模式的东西(赋值,匹配语句或for-comprehension中的一行)都可以使用提取器,该提取器被定义为具有unapply方法的实体.

scala为你提供的一种语法糖就是这样;如果你有一个提取器X(a,b),这可以写成X b.以下是案例类(具有默认提取器)的示例:

scala> case class X(a: Int, b: String)
defined class X

scala> val a X b = X(1, "two")
a: Int = 1
b: String = two

编写此类实体中缀的能力也扩展到了类型:

scala> type MappedTo[A, B] = Map[A, B]
defined type alias MappedTo

scala> def foo(m: Int MappedTo String) = m foreach println
foo: (m: MappedTo[Int,String])Unit

请注意,在这两种情况下,scala都不会将此类中缀运算符限制为符号标识符

翻译自:https://stackoverflow.com/questions/8665580/scala-match-case-using-for-lists


以上所述就是小编给大家介绍的《scala匹配案例使用:: for lists》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

并行算法的设计与分析

并行算法的设计与分析

陈国良 / 2009-8 / 66.00元

第3版在修订版的基础上进行了大幅度的修订,新增加3章、重写3章,改写8章。《普通高等教育十一五国家级规划教材·并行算法的设计与分析(第3版)》系统深入地讨论了计算机领域中诸多计算问题的并行算法的设计和分析方法。在着重介绍各种并行计算模型上的常用和典型的并行算法的同时,也力图反映本学科的最新成就、学科前沿和发展趋势。 全书共分二十章,包括基础篇4章(绪论、设计技术、前缀计算、排序和选择网络),......一起来看看 《并行算法的设计与分析》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具