如何scala-arm
在下面的代码中使用以便inputStream
自动发布?
def inflate(data: Array[Byte]): Array[Byte] = {
val inputStream = new InflaterInputStream(new ByteArrayInputStream(data), new Inflater)
Stream.continually(inputStream.read).takeWhile(-1 !=).map(_.toByte).toArray
}
我已经尝试过这样的事情......但当然最后一条语句失败了,因为方法toArray
不是 resource.ExtractableManagedResource
:
def inflate(data: Array[Byte]): Array[Byte] = {
val outputStream = for {
inputStream <- managed(new InflaterInputStream(new ByteArrayInputStream(data), new Inflater))
} yield Stream.continually(inputStream.read).takeWhile(-1 !=).map(_.toByte)
outputStream.toArray
}
这是我如何scala-arm
用于管理输出流的工作示例:
def deflate(data: Array[Byte]) = {
val outputStream = new ByteArrayOutputStream
for (deflaterOutputStream <- managed(new DeflaterOutputStream(outputStream, new Deflater))) {
deflaterOutputStream.write(data)
}
outputStream.toByteArray
}
是否有更简洁、面向 Scala 的方式来处理托管资源和scala-arm
(或scalax.io
)?