私はJDK 1.7.0_03を開くために、OracleのJDK 1.6から切り替えた、と私は終了時に、むしろ注目すべきデッドロックヒットしました:LinuxではSystem.exitはスレッドセーフではありませんか?
java.lang.Thread.State: WAITING (on object monitor)
at java.lang.Object.wait(Native Method)
at java.lang.Thread.join(Thread.java:1258)
- locked <0x8608dda0> (a sun.awt.X11.XToolkit$1$1)
at java.lang.Thread.join(Thread.java:1332)
at java.lang.ApplicationShutdownHooks.runHooks(ApplicationShutdownHooks.java:106)
at java.lang.ApplicationShutdownHooks$1.run(ApplicationShutdownHooks.java:46)
at java.lang.Shutdown.runHooks(Shutdown.java:123)
at java.lang.Shutdown.sequence(Shutdown.java:167)
at java.lang.Shutdown.exit(Shutdown.java:212)
- locked <0x8603df28> (a java.lang.Class for java.lang.Shutdown)
at java.lang.Runtime.exit(Runtime.java:107)
at java.lang.System.exit(System.java:960)
をあなたがAWTからのSystem.exitを呼び出す必要がありますことが表示されますイベントキュー。これは本当ですか? Sun docsにスレッド要件のドキュメントはありませんRuntime.exit
AWTツリーロックを取得する必要があるのはLinuxのみですが、これはケーキを取ります。これはバグですか?またはドキュメントに何かが欠けていますか?
は、デッドロックを実証SSCCE(http://sscce.org/)を手に入れましたか? – NPE
'System.exit'メソッドは、Java仮想マシン内のすべてのスレッドの強制終了を強制します。 System.exitを使用して前述のデッドロック問題を解決していない場合、デッドロックが発生する前にプログラムを停止しています。あなたが正常に停止すると、他のスレッドはメインスレッドの助けを借りずに続行され、明らかにそれらなしでは実行できません。 –