模式匹配(2)scala 里是怎么实现的?

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

内容简介:模式匹配(2)scala 里是怎么实现的?

参考博客: http://hongjiang.info/scala-pattern-matching-2/

文章中提到的有6种实现模式匹配的方法:

1.面向对象的分解 (decomposition)

2.访问器模式 (visitor)

3.类型测试/类型造型 (type-test/type-cast)

4.typecase

5.样本类 (case class)

6.抽取器 (extractor)

我直接说结果了,,,,

scala 直接选择了 样本类(case class)和抽取器(extractor)来实现模式匹配

样本类(case class):

case class实际上是scala的语法糖。case class 创建的类型,同时还帮你生成好了 一系列相应的方法,如:toString,hashCode,等方法。

最重要的是帮我们生成了一个伴生对象。这个伴生对象中定义了apply()和unapply 方法、

apply 方法 主要用于构建对象时使用,减少使用new 关键字。构造(工厂模式)

unappy 方法则是为模式匹配所服务。解构(解构模式)

case class 在模式匹配的时候暴露了其构造方法。所以当我们只想把类型暴露给用户,其内部数据表征想对其隐藏时,不宜使用。

抽取器(extractor):

抽取器是指定义了unapply方法的object。在进行模式匹配的时候会调用该方法。

unapply方法接受一个数据类型,返回另一数据类型,表示可以把入参的数据解构为返回的数据。

比如:

模式匹配(2)scala 里是怎么实现的? 模式匹配(2)scala 里是怎么实现的?

模式匹配(2)scala 里是怎么实现的?

它与上面的case class相比,相当于自己手动实现unapply,这也带来了灵活性。

其就可以解决上面case class 不想暴露具体的类型的缺陷了。如下代码具体讲解了其是怎么实现的:

模式匹配(2)scala 里是怎么实现的?

模式匹配(2)scala 里是怎么实现的?


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

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

淘宝十年产品事

淘宝十年产品事

苏杰 / 电子工业出版社 / 2013-10-15 / 55.00

产品经理发展到一定阶段,再要成长,光靠学习一些知识、技能已经不够,必须通过经典案例来学习,而本书,就提供了小到页面细节、大到平台架构的丰富案例。电商从业者,无法无视“淘宝”这个标杆的存在,本书可帮助大家做出更好的选择。愿意思考的人们,也可以从“淘宝”这个产品,或者说社会 现象、经济现象里,找到每天都能体会到的那些变化的原因,从而想得更明白,活得更通透。 本书细数淘宝成立十年来经历的重大变化,......一起来看看 《淘宝十年产品事》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

URL 编码/解码
URL 编码/解码

URL 编码/解码

MD5 加密
MD5 加密

MD5 加密工具