欢迎您访问365答案网,请分享给你的朋友!
生活常识 学习资料

一天学完spark的Scala基础语法教程十二、异常处理

时间:2023-07-27

前言

博客主页:红目香薰_CSDN博客-大数据,计算机理论,MySQL领域博主

✍本文由在下【红目香薰】原创,首发于CSDN✍

珞2022年最大愿望:【服务百万技术人次】珞

初始环境地址:【spark环境搭建(idea版本)_红目香薰-CSDN博客】

环境需求

环境:win10

开发工具:IntelliJ IDEA 2021.2

maven版本:3.6.3

目录

前言

环境需求

Scala 异常处理

抛出异常

捕获异常

finally 语句

总结


创建测试类【day1/demo12.scalc】,类型为【Object】

  

Scala 异常处理

Scala 的异常处理和其它语言比如 Java 类似。

Scala 的方法可以通过抛出异常的方法的方式来终止相关代码的运行,不必通过返回值。

抛出异常

Scala 抛出异常的方法和 Java一样,使用 throw 方法,例如,抛出一个新的参数异常:

throw new IllegalArgumentException

捕获异常

异常捕捉的机制与其他语言中一样,如果有异常发生,catch 字句是按次序捕捉的。因此,在 catch 字句中,越具体的异常越要靠前,越普遍的异常越靠后。 如果抛出的异常不在 catch 字句中,该异常则无法处理,会被升级到调用者处。

捕捉异常的 catch 子句,语法与其他语言中不太一样。在 Scala 里,借用了模式匹配的思想来做异常的匹配,因此,在 catch 的代码里,是一系列 case 字句,如下例所示:

package day1import java.io.FileReaderimport java.io.FileNotFoundExceptionimport java.io.IOExceptionobject demo12 { def main(args: Array[String]) { try { val f = new FileReader("input.txt") } catch { case ex: FileNotFoundException =>{ println("没有这个文件") } case ex: IOException => { println("IO Exception:IO异常") } } }}

通过这个案例我们能知道报错的具体异常。 

finally 语句

finally 语句用于执行不管是正常处理还是有异常发生时都需要执行的步骤,实例如下:

package day1import java.io.FileReaderimport java.io.FileNotFoundExceptionimport java.io.IOExceptionobject demo12 { def main(args: Array[String]) { try { val f = new FileReader("input.txt") } catch { case ex: FileNotFoundException =>{ println("没有这个文件") } case ex: IOException => { println("IO Exception:IO异常") } } finally { println("无论对错,finally都会执行(前提是不关闭虚拟机。)") } }}

总结

到这里有关一天学完spark的Scala基础语法教程十二、异常处理(idea版本)就结束了。

希望能对大家有所帮助。

欢迎一键三连,谢谢。

 

Copyright © 2016-2020 www.365daan.com All Rights Reserved. 365答案网 版权所有 备案号:

部分内容来自互联网,版权归原作者所有,如有冒犯请联系我们,我们将在三个工作时内妥善处理。