Идиоматический способ преобразования InputStream в строку в Scala
У меня есть удобная функция, которую я использовал в Java для преобразования InputStream в строку. Вот прямой перевод на Scala:
def inputStreamToString(is: InputStream) = {
val rd: BufferedReader = new BufferedReader(new InputStreamReader(is, "UTF-8"))
val builder = new StringBuilder()
try {
var line = rd.readLine
while (line != null) {
builder.append(line + "\n")
line = rd.readLine
}
} finally {
rd.close
}
builder.toString
}
Есть ли идиоматический способ сделать это в Scala?
3 ответа
Решение
Для Scala >= 2.11
scala.io.Source.fromInputStream(is).mkString
Для Scala < 2.11:
scala.io.Source.fromInputStream(is).getLines().mkString("\n")
делает почти то же самое. Не уверен, почему вы хотите получить строки, а затем склеить их все вместе. Если вы можете предполагать неблокирование потока, вы можете просто использовать .available
, прочитайте все это в байтовом массиве и создайте строку из этого непосредственно.
Source.fromInputStream(is).mkString("")
также сделаю дело.....
Более быстрый способ сделать это:
private def inputStreamToString(is: InputStream) = {
val inputStreamReader = new InputStreamReader(is)
val bufferedReader = new BufferedReader(inputStreamReader)
Iterator continually bufferedReader.readLine takeWhile (_ != null) mkString
}