InterruptedException выдается при запуске бета-приложения JavaFx 2.0 из sbt 0.10.1 - PullRequest
4 голосов
/ 05 августа 2011

При попытке запустить простое бета-приложение JavaFX 2.0, написанное на Scala 2.8.1 из sbt 0.10.1, после закрытия окна приложения выдается исключение:

> run
[info] Running com.tradex.priceviewer.Main
  Exception while removing reference: java.lang.InterruptedException
  java.lang.InterruptedException
  [       at java.lang.Object.wait(Native Method)success
  ]       at java.lang.ref.ReferenceQueue.remove(Unknown Source)Total time: 5 s, completed Aug 5, 2011 1:12:04 PM

  at java.lang.ref.ReferenceQueue.remove(Unknown Source)
  at com.sun.glass.utils.Disposer.run(Disposer.java:64)>
  at java.lang.Thread.run(Unknown Source)

При запуске приложения изв командной строке не выдается никаких исключений, а возвращаемый статус равен 0. Код приложения приведен ниже:

class Starter extends Application {

  def main(args: Array[String]) {
   Application.launch(args)
  } 

  override def start(s: Stage) {
   s.setVisible(true)
  }
}

object Main {

  def main(args: Array[String]) {
    val gui = new Starter
    gui.main(args)
  }
}

После того, как возникло исключение, необходимо выйти и запустить sbt снова (перезагрузка не работает).При запуске того же приложения из консоли Scala 2.8.1 после второго запуска выдается следующее исключение:

scala> m.main(Array(""))

scala> m.main(Array(""))
java.lang.IllegalStateException: Application launch must not be called more than once
    at com.sun.javafx.application.LauncherImpl.launchApplication(LauncherImpl.java:41)
    at javafx.application.Application.launch(Application.java:115)
    at com.tradex.priceviewer.Starter.main(Main.scala:19)
    at .<init>(<console>:11)
    at .<clinit>(<console>)
    at RequestResult$.<init>(<console>:9)
    at RequestResult$.<clinit>(<console>)
    at RequestResult$scala_repl_result(<console>)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at scala.tools.nsc.Interpreter$Request$$anonfun$loadAndRun$1$$anonfun$apply$17.appl...
scala>

Кто-нибудь знает, как правильно выйти из этого приложения scala / javafx (так что никто не будетнужно перезапустить консоль sbt или scala)?

1 Ответ

7 голосов
/ 22 августа 2011

Мне удалось воспроизвести это на моей системе.Я обнаружил, что при запуске из sbt возникла исключительная ситуация InterruptedException, а из командной строки приложение работало нормально.

Я добавил следующее в настройки проекта в SBT:

fork in run := true

Это указывает SBT запускать приложение (и тесты) в отдельной JVM, а не в самом SBT.После этого я могу запустить приложение несколько раз и не получаю InterruptedException.

Я думаю, что здесь вы можете столкнуться с SecurityManager, который SBT использует при запуске приложений в той же JVM.Он не должен иметь возможность обрабатывать то, что делает приложение JavaFX.Запустив отдельную JVM, вы обойдете это.

...