主页 > 新闻资讯 > 大数据培训:Scala编程之异常处理

大数据培训:Scala编程之异常处理

作者:张老师 浏览次数: 2021-04-02 17:32
异常处理是编程任务当中常常需要去解决的问题。简单来说,异常处理就是在程序运行当中出现问题时,用来打断程序执行的方式。而Scala当中,异常处理的实现与Java类似,我们可以对比起来理解。今天的大数据培训分享,我们就来讲讲Scala编程之异常处理。

大数据培训:Scala编程之异常处理

Scala通过捕获异常,捕获后可以进行处理,或者抛出给上游程序,抛出异常的方法和 Java一样,使用 throw 关键字。

如要对一段代码的执行进行异常检测,使用try将这段代码包起来,在catch语句中进行异常的匹配,借用了模式匹配的思想catch语句中是一系列的case字句。需要注意的是与try……catch成对出现的还有finally语句-用于执行不管是正常处理还是有异常发生时都需要执行的步骤。

Scala异常处理

1、捕获异常的方式

java中是通过多个catch子句来捕获不同类型的异常,而在scala中是通过一个catch子句,加上模式匹配的类型匹配方式来捕获不同类型的异常。如下图所示:

大数据培训:Scala编程之异常处理

2、scala没有checked异常

在java中,非运行时异常在编译期是会被强制检查的,要么写try...catch...处理,要么使用throws关键字,将异常抛给调用者处理。而在scala中,更推崇通过使用函数式结构和强类型来减少对异常及其处理的依赖。因此scala不支持检查型异常(checked exception)。

当使用scala调用java类库时,scala会把java代码中声明的异常,转换为非检查型异常。

3、scala在throw异常时是有返回值的

在scala的设计中,所有表达式都是有返回值的。那么,自然throw表达式也不例外,throw表达式的返回值为Nothing。由于Nothing类型是所有类型的子类型,因此throw表达式可以出现在任意位置,而不会影响到类型的推断。

Scala类型层级

在scala中,所有的值都是有类型的,包括数值型值和函数,比java更加彻底地贯彻了万物皆对象的理念。因此,scala有一套自己的类型层级,如下图所示:

大数据培训:Scala编程之异常处理

scala的顶级类是Any,下面包含两个子类,AnyVal和AnyRef,其中AnyVal是所有值类型的父类,其中包含一个特殊的值Unit;而AnyRef是所有引用类型的父类,所有java类型和非值类型的scala类型都是它的子类。

其中,有两个比较特殊的底层子类型,一个是Null,它是所有引用类型的子类型,可以赋给任何引用类型变量;另一个是Nothing,它是所有类型的子类,因此既可以赋给引用类型变量,也可以赋给值类型变量。

关于大数据培训,Scala编程之异常处理,以上就为大家做了一个简单的入门介绍了。如果自身有不错的Java基础,可以将两者对比起来看,更加利于理解和掌握。成都加米谷大数据,专业大数据培训机构,大数据开发、数据分析与挖掘,零基础班本月正在招生中,课程大纲及学习视频资料可联系客服获取!

热点排行
推荐文章
立即申请>>