我试图做一些scripting in Scala来处理一些日志文件:
scala> import io.Source
import io.Source
scala> import java.io.File
import java.io.File
scala> val f = new File(".")
f: java.io.File = .
scala> for (l <- f.listFiles) {
| val src = Source.fromFile(l).getLines
| println( (0 /: src) { (i, line) => i + 1 } )
| }
3658
java.nio.BufferUnderflowException
at java.nio.Buffer.nextGetIndex(Unknown Source)
at java.nio.HeapCharBuffer.get(Unknown Source)
at scala.io.BufferedSource$$anon$2.next(BufferedSource.scala:86)
at scala.io.BufferedSource$$anon$2.next(BufferedSource.scala:74)
at scala.io.Source$$anon$6.next(Source.scala:307)
at scala.io.Source$$anon$6.next(Source.scala:301)
at scala.Iterator$cla...
为什么我会收到此java.nio.BufferUnderflowException
?
注意 - 我正在处理10个日志文件,每个文件大小约为1MB
答案 0 :(得分:6)
当我使用错误的编码打开文件时,我遇到BufferUnderflowException
异常。它包含非法字符(根据错误的编码)并且抛出了这种误导性的异常。
答案 1 :(得分:2)
我也很感兴趣为什么会发生这种情况,但我猜这是因为Source
是一个对象(即单例)以及它是如何透明地获取 重置。您可以按如下方式解决问题:
for (l <- g.listFiles if !l.isDirectory) {
| val src = Source.fromFile(l)
| println( (0 /: src.getLines) { (i, line) => i + 1 } )
| src.reset
| }
重要的一点是 reset
- 它可能位于try-finally
块中(尽管isDirectory
测试也可能有用)
答案 2 :(得分:1)
这实际上是对Elazar答案的重述,但如果您尝试使用scala.io.Source.fromFile
读取二进制文件,也会遇到此异常。
由于我写的东西中有一个非常愚蠢的错误,我刚碰到这个(不小心试图用fromFile
读取一个.jpg)