Идиоматический способ преобразования 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
    }
Другие вопросы по тегам