scala异常处理

scala的异常机制和java的异常机制是一样的,抛出的异常必须是java.lang.Throwable的子类,但是scala中没有“受检”异常的机制。

//这是java的“受检”异常的方式,在可能抛出异常的方法上做出声明
//scala中没有这样的方式
public void doSomething() throws IOException{
    ....
}

 throw表达式,throw new RuntimeExcepton("......")其实是返回Nothing类型的对象,以if/else举例,如果一个分支返回Int类型的数据,另一个分支返回throw new RuntimeExcepton("......")也就是Nothing类型,if/else表达式返回值类型就是throw new RuntimeExcepton("......")对应分支的另一个分支的返回值类型。举例说明:


scala> val aa = (x : Int) => if(x > 0) x else throw new RuntimeException("haha")

aa: Int => Int = $$Lambda$1058/2636011@2d459bda

aa函数的返回值是Int类型。

scala和java一样,都支持try{......}catch{......}finally{......}的形式捕获异常,但是,scala是以模式匹配的方式捕获异常的。

如果不需要使用捕获到的异常,可以使用_代替变量名。


scala> try{
     |   throw new RuntimeException("i am RuntimeException")
     | } catch{
     |   case _ : IllegalArgumentException => println("haha") //如果不需要使用这个异常,用_代替变量
     |   case e1 : RuntimeException => e1.printStackTrace()
     | } finally{
     |   println("i am finally")
     | }
java.lang.RuntimeException: i am RuntimeException //捕获到了RuntimeException 
        at $line7.$read$$iw$$iw$.liftedTree1$1(:13)
        at $line7.$read$$iw$$iw$.(:12)
        at $line7.$read$$iw$$iw$.()
        at $line7.$eval$.$print$lzycompute(:7)
        at $line7.$eval$.$print(:6)
        at $line7.$eval.$print()
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
       //此处省略RuntimeException的打印内容
i am finally //执行了finally代码块里的内容

 

你可能感兴趣的:(scala基础)