Spark记录-Scala异常处理与文件I/O
Scala的异常处理类似许多其他语言(如Java)。它不是以正常方式返回值,方法可以通过抛出异常来终止。 但是,Scala实际上并没有检查异常。
当您想要处理异常时,要像Java一样使用try {...} catch {...}
块,除了catch
块使用匹配来识别和处理异常。
引发异常
抛出异常看起来与Java中的异常一样。创建一个异常对象,然后使用throw
关键字将其抛出如下。
throw new IllegalArgumentException
捕获异常
Scala允许在单个块中try/catch
任何异常,然后使用case
块对其进行模式匹配。尝试以下示例程序来处理异常。
import java.io.FileReader
import java.io.FileNotFoundException
import java.io.IOException
object Demo {
def main(args: Array[String]) {
try {
val f = new FileReader("input.txt")
} catch {
case ex: FileNotFoundException =>{
println("Missing file exception")
}
case ex: IOException => {
println("IO Exception")
}
}
}
}
将上述程序保存在源文件:Demo.scala中,使用以下命令编译和执行此程序。
D:\>scalac Demo.scala
D:\>scala Demo
Missing file exception
try-catch
表达式的行为与其他具有异常的语言相同。它在主体中执行,如果它抛出一个异常,则会依次尝试每个catch
子句。
finally子句
如果希望引发一些代码执行,无论表达式如何终止,都会执行在finally
子句包装表达式。尝试以下程序。
import java.io.FileReader
import java.io.FileNotFoundException
import java.io.IOException
object Demo {
def main(args: Array[String]) {
try {
val f = new FileReader("input.txt")
} catch {
case ex: FileNotFoundException => {
println("Missing file exception")
}
case ex: IOException => {
println("IO Exception")
}
} finally {
println("Exiting finally...")
}
}
}
将上述程序保存在源文件:Demo.scala中,使用以下命令编译和执行此程序。
D:\>scalac Demo.scala
D:\>scala Demo
Missing file exception
Exiting finally...
Scala文件I/O
Scala可以使用任何Java对象,而java.io.File
是Scala编程中可用于读取和写入文件的对象之一。
以下是写入文件的示例程序。
import java.io._
object Demo {
def main(args: Array[String]) {
val writer = new PrintWriter(new File("test.txt" ))
writer.write("Hello Scala")
writer.close()
}
}
将上述程序保存在源文件:Demo.scala中,使用以下命令编译和执行此程序。
D:\>scalac Demo.scala
D:\>scala Demo
Hello Scala
从命令行读一行
有时需要从屏幕上读取用户输入,然后继续进行进一步的处理。 以下示例程序显示如何从命令行读取输入。
object Demo {
def main(args: Array[String]) {
print("Please enter your input : " )
val line = Console.readLine
println("Thanks, you just typed: " + line)
}
}
将上述程序保存在源文件:Demo.scala中,使用以下命令编译和执行此程序。
D:\>scalac Demo.scala
D:\>scala Demo
Please enter your input : Scala is great
Thanks, you just typed: Scala is great
阅读文件内容
从文件读取真的很简单。可以使用Scala的Source
类及其对象来读取文件。以下是从前面创建的“Demo.txt”
文件中读取的示例。
import scala.io.Source
object Demo {
def main(args: Array[String]) {
println("Following is the content read:" )
Source.fromFile("Demo.txt" ).foreach {
print
}
}
}
将上述程序保存在源文件:Demo.scala中,使用以下命令编译和执行此程序。
D:\>scalac Demo.scala
D:\>scala Demo
Following is the content read:
Hello Scala