Scala Stdin.readLine()似乎没有按预期工作

时间:2015-04-09 12:41:03

标签: scala io console sbt

我正在尝试编写一个简单的控制台客户端应用程序,我可以向用户提供一些选项,获取他们的输入并采取相应的行动。如果我通过intellij运行代码或将其粘贴到scala控制台,它可以工作。如果我通过sbt运行它(这是我真正需要它运行的方式),我会遇到各种各样的问题。

我有版本0.13.8,操作系统是Mac,我的build.sbt包含:

scalaVersion := "2.11.6"
fork in run := true

编辑我开始使用最小scala激活器模板,以防在此上下文中有用的信息

我已将代码简化为准系统,

import scala.io.StdIn._

object TestClient {
  def main(args: Array[String]): Unit = {
    join()
  }

  def join(): Unit = {
    val name = readLine(s"Enter your name.${System.getProperty("line.separator")}")
    name match {
      case n: String => println(n)
      case o => {
        println(s"invalid name ${o}")
        join()
      };
    }
  }
}

进入sbt并从提示符输入run。以下之一似乎发生了

1)我一跑完就得到这个例外

Exception in thread "Thread-2" java.lang.OutOfMemoryError: Java heap space
        at java.util.Arrays.copyOf(Arrays.java:3332)
        at java.lang.AbstractStringBuilder.expandCapacity(AbstractStringBuilder.java:137)
        at java.lang.AbstractStringBuilder.ensureCapacityInternal(AbstractStringBuilder.java:121)
        at java.lang.AbstractStringBuilder.append(AbstractStringBuilder.java:569)
        at java.lang.StringBuffer.append(StringBuffer.java:369)
        at java.io.BufferedReader.readLine(BufferedReader.java:370)
        at java.io.BufferedReader.readLine(BufferedReader.java:389)
        at sbt.BasicIO$$anonfun$processFully$1$$anonfun$apply$8.apply(ProcessImpl.scala:58)
        at sbt.BasicIO$$anonfun$processFully$1$$anonfun$apply$8.apply(ProcessImpl.scala:58)
        at sbt.BasicIO$.readFully$1(ProcessImpl.scala:63)
        at sbt.BasicIO$.processLinesFully(ProcessImpl.scala:69)
        at sbt.BasicIO$$anonfun$processFully$1.apply(ProcessImpl.scala:58)
        at sbt.BasicIO$$anonfun$processFully$1.apply(ProcessImpl.scala:55)
        at sbt.SimpleProcessBuilder$$anonfun$3.apply$mcV$sp(ProcessImpl.scala:354)
        at sbt.Spawn$$anon$3.run(ProcessImpl.scala:17)

2) 没有内存问题,但是在无限循环中获取这些消息,因此readline似乎没有等待任何输入

background log: info: Enter your name.
background log: info: invalid name null
background log: info: Enter your name.
background log: info: invalid name null
...

无论哪种方式,我都无法在控制台中实际输入任何输入。不确定我错过了什么或做错了

1 个答案:

答案 0 :(得分:10)

connectInput in run := true

build.sbt中。有关如何在sbt中正确处理分支的详细信息,请参阅official docs