I have a javafx 8 app that has multiple active thread when I want to close it, this code shows 8 active threads :
ThreadGroup group = Thread.currentThread().getThreadGroup();
LOG.debug("Number of active threads = " + group.activeCount());
Using Platform.exit();
and Platform.setImplicitExit(true);
doesn't get me a clean exit.
I tried killing all threads before or after calling Platform.exit();
but without success.
Even setting threads as deamons before interrupting didn't solve it.
while (group != null) {
group.setDaemon(true);
group.interrupt();
group = Thread.currentThread().getThreadGroup();
}
Calling System.exit(0)
is not an option here as other apps can be launched from within other apps or standalone.
The error shown before exit is Not on FX application thread; currentThread = JavaFX Application Thread
.
Edit 1: the stack trace of the error :
ERROR SimpleUncaughtExceptionHandler.java uncaughtException 34 [JavaFX Application Thread] Uncaught exception
java.lang.IllegalStateException: Not on FX application thread; currentThread = JavaFX Application Thread
at com.sun.javafx.tk.Toolkit.checkFxUserThread(Toolkit.java:236) ~[jfxrt.jar:?]
at com.sun.javafx.tk.quantum.QuantumToolkit.checkFxUserThread(QuantumToolkit.java:423) ~[jfxrt.jar:?]
at javafx.stage.Window.setShowing(Window.java:921) ~[jfxrt.jar:?]
at javafx.stage.Window.hide(Window.java:947) ~[jfxrt.jar:?]
at com.sun.javafx.stage.WindowPeerListener.closed(WindowPeerListener.java:100) ~[jfxrt.jar:?]
at com.sun.javafx.tk.quantum.GlassWindowEventHandler.run(GlassWindowEventHandler.java:118) ~[jfxrt.jar:?]
at com.sun.javafx.tk.quantum.GlassWindowEventHandler.run(GlassWindowEventHandler.java:40) ~[jfxrt.jar:?]
at java.security.AccessController.doPrivileged(Native Method) ~[?:1.8.0_121]
at com.sun.javafx.tk.quantum.GlassWindowEventHandler.lambda$handleWindowEvent$423(GlassWindowEventHandler.java:150) ~[jfxrt.jar:?]
at com.sun.javafx.tk.quantum.QuantumToolkit.runWithoutRenderLock(QuantumToolkit.java:389) ~[jfxrt.jar:?]
at com.sun.javafx.tk.quantum.GlassWindowEventHandler.handleWindowEvent(GlassWindowEventHandler.java:148) ~[jfxrt.jar:?]
at com.sun.glass.ui.Window.handleWindowEvent(Window.java:1266) ~[jfxrt.jar:?]
at com.sun.glass.ui.Window.notifyDestroy(Window.java:1183) ~[jfxrt.jar:?]
Edit 2 : List of active threads:
DEBUG [JavaFX Application Thread] isDeamon : false; name : main
DEBUG [JavaFX Application Thread] isDeamon : true; name : QuantumRenderer-0
DEBUG [JavaFX Application Thread] isDeamon : false; name : JavaFX-Launcher
DEBUG [JavaFX Application Thread] isDeamon : true; name : URL-Loader-2
DEBUG [JavaFX Application Thread] isDeamon : true; name : URL-Loader-1
DEBUG [JavaFX Application Thread] isDeamon : true; name : JavaFX Application Thread
DEBUG [JavaFX Application Thread] isDeamon : true; name : Java2D Queue Flusher
DEBUG [JavaFX Application Thread] isDeamon : true; name : Prism Font Disposer
DEBUG [JavaFX Application Thread] isDeamon : true; name : Reference Handler
DEBUG [JavaFX Application Thread] isDeamon : true; name : Thread-6
DEBUG [JavaFX Application Thread] isDeamon : false; name : AWT-Shutdown
DEBUG [JavaFX Application Thread] isDeamon : true; name : Java2D Disposer
DEBUG [JavaFX Application Thread] isDeamon : true; name : Signal Dispatcher
DEBUG [JavaFX Application Thread] isDeamon : true; name : Disposer
DEBUG [JavaFX Application Thread] isDeamon : true; name : Finalizer
DEBUG [JavaFX Application Thread] isDeamon : false; name : AWT-EventQueue-0
DEBUG [JavaFX Application Thread] isDeamon : true; name : Thread-5
DEBUG [JavaFX Application Thread] isDeamon : true; name : Timer-0