我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Scala模式匹配的方法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Scala模式匹配的方法

这篇文章主要介绍“Scala模式匹配的方法”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Scala模式匹配的方法”文章能帮助大家解决问题。

Scala模式匹配的方法

简单匹配

Scala的模式匹配最常用于match语句中。下面是一个简单的整型值的匹配实例。

val colorNum = 1val colorStr = colorNum match {   case 1 => "red"   case 2 => "green"   case 3 => "yellow"   case _ => "Not Allowed"}println(colorStr)

为了测试上面代码,可以直接把上面代码放入到“/usr/local/scala/mycode/test.scala”文件中,然后,在Linux系统的Shell命令提示符状态下执行下面命令:

scala test.scala

Shell 命令

另外,在模式匹配的case语句中,还可以使用变量。

val colorNum = 4val colorStr = colorNum match {   case 1 => "red"   case 2 => "green"   case 3 => "yellow"   case unexpected => unexpected + " is Not Allowed"  }println(colorStr)

按照前面给出的方法,在test.scala文件中测试执行上述代码后会在屏幕上输出:

4 is Not Allowed

也就是说,当colorNum=4时,值4会被传递给unexpected变量。

类型模式

Scala可以对表达式的类型进行匹配。

for (elem "Spark","Hadoop",'Hello)){   val str  = elem match{       case i: Int => i + " is an int value."       case d: Double => d + " is a double value."       case "Spark"=> "Spark is found."       case s: String => s + " is a string value."       case _ => "This is an unexpected value."   }println(str)    }

在test.scala文件中测试执行上述代码后会在屏幕上输出:

9 is an int value.12.3 is a double value.Spark is found.Hadoop is a string value.This is an unexpected value.

“守卫(guard)”语句

可以在模式匹配中添加一些必要的处理逻辑。

for (elem case _ if (elem %2 == 0) => println(elem + " is even.")           case _ => println(elem + " is odd.")   }}

上面代码中if后面条件表达式的圆括号可以不要。执行上述代码后可以得到以下输出结果:

1 is odd.2 is even.3 is odd.4 is even.

for表达式中的模式

我们之前在介绍“映射”的时候,实际上就已经接触过了for表达式中的模式。 还是以我们之前举过的映射为例子,我们创建的映射如下:

val university = Map("XMU" -> "Xiamen University", "THU" -> "Tsinghua University","PKU"->"Peking University")

循环遍历映射的基本格式是:

for ((k,v)

对于遍历过程得到的每个值,都会被绑定到k和v两个变量上,也就是说,映射中的“键”被绑定到变量k上,映射中的“值”被绑定到变量v上。

下面给出此前已经介绍过的实例:

for ((k,v) printf("Code is : %s and name is: %s\n",k,v)

上面代码执行结果如下:

Code is : XMU and name is: Xiamen UniversityCode is : THU and name is: Tsinghua UniversityCode is : PKU and name is: Peking University

case类的匹配

case类是一种特殊的类,它们经过优化以被用于模式匹配。

case class Car(brand: String, price: Int)val myBYDCar = new Car("BYD", 89000)val myBMWCar = new Car("BMW", 1200000)val myBenzCar = new Car("Benz", 1500000)for (car case Car("BYD", 89000) => println("Hello, BYD!")       case Car("BMW", 1200000) => println("Hello, BMW!")       case Car(brand, price) => println("Brand:"+ brand +", Price:"+price+", do you want it?")           }}

把上述代码放入test.scala文件中,运行“scala test.scala”命令执行后可以得到如下结果:

Hello, BYD!Hello, BMW!Brand: Benz, Price:1500000, do you want it?

Option类型

标准类库中的Option类型用case类来表示那种可能存在、也可能不存在的值。 一般而言,对于每种语言来说,都会有一个关键字来表示一个对象引用的是“无”,在Java中使用的是null。Scala融合了函数式编程风格,因此,当预计到变量或者函数返回值可能不会引用任何值的时候,建议你使用Option类型。Option类包含一个子类Some,当存在可以被引用的值的时候,就可以使用Some来包含这个值,例如Some(“Hadoop”)。而None则被声明为一个对象,而不是一个类,表示没有值。 下面们给出一个实例。

//首先我们创建一个映射scala> val books=Map("hadoop"->5,"spark"->10,"hbase"->7)books: scala.collection.immutable.Map[String,Int] = Map(hadoop -> 5, spark -> 10, hbase -> 7) //下面我们从映射中取出键为"hadoop"对应的值,这个键是存在的,可以取到值,并且取到的值会被包含在Some中返回scala> books.get("hadoop")res0: Option[Int] = Some(5) //下面我们从映射中取出键为"hive"对应的值,这个键是不存在的,所以取到的值是None对象scala> books.get("hive")res1: Option[Int] = None

scala

Option类型还提供了getOrElse方法,这个方法在这个Option是Some的实例时返回对应的值,而在是None的实例时返回传入的参数。例如:

scala> val sales=books.get("hive")sales: Option[Int] = None scala> sales.getOrElse("No Such Book")res3: Any = No Such Book scala> println(sales.getOrElse("No Such Book"))No Such Book

scala

可以看出,当我们采用getOrElse方法时,如果我们取的”hive”没有对应的值,我们就可以显示我们指定的“No Such Book”,而不是显示None。 在Scala中,使用Option的情形是非常频繁的。在Scala里,经常会用到Option[T]类型,其中的T可以是Sting或Int或其他各种数据类型。Option[T]实际上就是一个容器,我们可以把它看做是一个集合,只不过这个集合中要么只包含一个元素(被包装在Some中返回),要么就不存在元素(返回None)。既然是一个集合,我们当然可以对它使用map、foreach或者filter等方法。比如:

scala> books.get("hive").foreach(println)

scala

可以发现,上述代码执行后,屏幕上什么都没有显示,因为,foreach遍历遇到None的时候,什么也不做,自然不会执行println操作。

关于“Scala模式匹配的方法”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Scala模式匹配的方法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Scala模式匹配的方法

这篇文章主要介绍“Scala模式匹配的方法”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Scala模式匹配的方法”文章能帮助大家解决问题。简单匹配Scala的模式匹配最常用于match语句中。下面是
2023-06-27

Scala中的模式匹配是什么

这篇文章主要介绍Scala中的模式匹配是什么,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Scala 是一门多范式(multi-paradigm)的编程语言,设计初衷是要集成面向对象编程和函数式编程的各种特性,Sca
2023-06-27

scala 调用 java 方法参数匹配问题

scala调用java的FastJson时发生了一个方法参数匹配问题: scala和java几乎没有区别,可以互相调用。注意这里说的是几乎,总有那么少数,出人意料的惊喜在告诉你,scala就是scala。 例子:
2023-06-03

PostgreSQL模式匹配与正则表达式方法总结

目录1.1 PostgreSQL中的模式匹配和正则表达式1.2 传统SQL的LIKE操作符1.3 SIMILAR TO正则表达式1.4 POSIX正则表达式1.5 模式匹配函数substring总结1.1 PostgreSQL中的模式匹配和
2022-11-19

elasticsearch模糊匹配的方法是什么

在Elasticsearch中,可以使用模糊匹配实现模糊搜索。以下是几种常用的模糊匹配方法:1. 通配符查询(Wildcard Query):使用通配符(*和?)进行模糊匹配。例如,使用"el*icse*ch"可以匹配到"elasticse
2023-10-11

opencv C++模板匹配的实现方法

这篇文章主要介绍“opencv C++模板匹配的实现方法”,在日常操作中,相信很多人在opencv C++模板匹配的实现方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”opencv C++模板匹配的实现方法
2023-06-29

掌握 JavaScript RegExp 方法:提升你的模式匹配游戏

JavaScript RegExp 方法:提升你的模式匹配实力
掌握 JavaScript RegExp 方法:提升你的模式匹配游戏
2024-03-09

匹配重复模式的正则表达式

小伙伴们有没有觉得学习Golang很有意思?有意思就对了!今天就给大家带来《匹配重复模式的正则表达式》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!问题内容我有以下输入文本:pagelimit=50&fi
匹配重复模式的正则表达式
2024-04-04

Javascala模式匹配机制详解

模式匹配语法中,采用match关键字声明,每个分支采用case关键字进行声明,当需要匹配时,会从第一个case分支开始,如果匹配成功,那么执行对应的逻辑代码,如果匹配不成功,继续执行下一个分支进行判断
2023-02-01

mongodb数字模糊匹配的方法是什么

在MongoDB中,可以使用正则表达式来实现数字模糊匹配。例如,假设有一个集合存储了一些文档,其中一个字段是数字类型。现在我们想要模糊匹配这个数字字段,可以使用正则表达式的方式来实现。以下是一个示例,展示了如何使用正则表达式进行数字模糊匹配
2023-08-23

Rust模式匹配示例详解

这篇文章主要为大家介绍了Rust模式匹配示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-11-13

JavaScala之模式匹配与隐式转换

在Java中我们有switchcasedefault这三个组成的基础语法,在Scala中我们是有match和case组成default的作用由case代替,本文详细介绍了Scala的模式匹配与隐式转换,感兴趣的可以参考本文
2023-05-18

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录