関数型プログラミング in ScalalinesGt1
の第 15 章の冒頭にある命令型の行カウント コード (「参考文献」を参照) を、 scalaz-stream (「参考文献」を参照)を使用するソリューションに翻訳しました。ただし、パフォーマンスはそれほど優れていません。命令型コードは、私の scalaz-stream ソリューションよりも約 30 倍高速です。だから私は根本的に間違ったことをしていると思います。scalaz-stream コードのパフォーマンスをどのように改善できますか?linesGt2
linesGt2
ここに私の完全なテストコードがあります:
import scalaz.concurrent.Task
import scalaz.stream._
object Test06 {
val minLines = 400000
def linesGt1(filename: String): Boolean = {
val src = scala.io.Source.fromFile(filename)
try {
var count = 0
val lines: Iterator[String] = src.getLines
while (count <= minLines && lines.hasNext) {
lines.next
count += 1
}
count > minLines
}
finally src.close
}
def linesGt2(filename: String): Boolean =
scalaz.stream.io.linesR(filename)
.drop(minLines)
.once
.as(true)
.runLastOr(false)
.run
def time[R](block: => R): R = {
val t0 = System.nanoTime()
val result = block
val t1 = System.nanoTime()
println("Elapsed time: " + (t1 - t0) / 1e9 + "s")
result
}
time(linesGt1("/home/frank/test.txt")) //> Elapsed time: 0.153122057s
//| res0: Boolean = true
time(linesGt2("/home/frank/test.txt")) //> Elapsed time: 4.738644606s
//| res1: Boolean = true
}