0


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

📋前言📋

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

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

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

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

环境需求

环境:win10

开发工具:IntelliJ IDEA 2021.2

maven版本:3.6.3

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

Scala 异常处理

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

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

抛出异常

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

  1. throw new IllegalArgumentException

捕获异常

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

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

  1. package day1
  2. import java.io.FileReader
  3. import java.io.FileNotFoundException
  4. import java.io.IOException
  5. object demo12 {
  6. def main(args: Array[String]) {
  7. try {
  8. val f = new FileReader("input.txt")
  9. } catch {
  10. case ex: FileNotFoundException =>{
  11. println("没有这个文件")
  12. }
  13. case ex: IOException => {
  14. println("IO Exception:IO异常")
  15. }
  16. }
  17. }
  18. }

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

finally 语句

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

  1. package day1
  2. import java.io.FileReader
  3. import java.io.FileNotFoundException
  4. import java.io.IOException
  5. object demo12 {
  6. def main(args: Array[String]) {
  7. try {
  8. val f = new FileReader("input.txt")
  9. } catch {
  10. case ex: FileNotFoundException =>{
  11. println("没有这个文件")
  12. }
  13. case ex: IOException => {
  14. println("IO Exception:IO异常")
  15. }
  16. } finally {
  17. println("无论对错,finally都会执行(前提是不关闭虚拟机。)")
  18. }
  19. }
  20. }

总结

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

希望能对大家有所帮助。

欢迎一键三连,谢谢。


本文转载自: https://blog.csdn.net/feng8403000/article/details/122716096
版权归原作者 红目香薰 所有, 如有侵权,请联系我们删除。

“一天学完spark的Scala基础语法教程十二、异常处理(idea版本)”的评论:

还没有评论