构建JFrame时,Java Web Start会挂起

时间:2010-11-08 14:34:38

标签: java jframe java-web-start

使用Java Web Start启动程序时需要帮助。

我从主页启动我的程序,程序只是在进程处理程序中挂起了一个javaw-process。当我使用jvisualvm转储线程时,我看到它挂在“AWT-EventQueue-0”线程中(构建我的JFrame时):

"AWT-EventQueue-0" prio=6 tid=0x02da7c00 nid=0x1414 runnable [0x0367f000]
    java.lang.Thread.State: RUNNABLE
        at sun.awt.windows.WToolkit.getScreenInsets(Native Method)
        at sun.awt.windows.WToolkit.getScreenInsets(Unknown Source)
        at java.awt.Window.init(Unknown Source)
        at java.awt.Window.<init>(Unknown Source)
        at java.awt.Frame.<init>(Unknown Source)
        at javax.swing.JFrame.<init>(Unknown Source)
        at se.testing.Application$2.run(Application.java:170)
        at java.awt.event.InvocationEvent.dispatch(Unknown Source)
        at java.awt.EventQueue.dispatchEvent(Unknown Source)
        at java.awt.EventDispatchThread.pumpOneEventForFilters(Unknown Source)
        at java.awt.EventDispatchThread.pumpEventsForFilter(Unknown Source)

以下是主要内容:

public static void main(String... args) {

    ....

    SwingUtilities.invokeLater(new Runnable() {
        public void run() {
            JFrame f = new JFrame("Test");
            ...
        }
    });
}

更新:这是jnlp文件:

<?xml version="1.0" encoding="utf-8"?>
<jnlp spec="6.0+" 
      codebase="http://localhost/archive/Application-1.0.0/"
      href="application.jnlp">
  <information>
    <title>Application</title>
    <vendor>Testing</vendor>
    <homepage href="http://localhost/" />
    <description></description>
    <offline-allowed/>
  </information>
  <security>
    <all-permissions/>
  </security>
  <update check="timeout" policy="always" />
  <resources>
    <j2se version="1.6+"/>
    <jar href="Application-1.0.0.jar" main="true"/>
    <jar href="Framework-1.0.0.jar"/>
    <jar href="WebServices-1.0.0.jar"/>
    <jar href="axis-1.4.jar"/>
    <jar href="axis-jaxrpc-1.4.jar"/>
    <jar href="log4j-1.2.14.jar"/>
    <jar href="spring-2.5.5.jar"/>
    <jar href="commons-logging-1.1.1.jar"/>
    <jar href="commons-net-2.0.jar"/>
    <jar href="nanoxml-2.2.3.jar"/>
    <jar href="jtds-1.2.2.jar"/>
    <jar href="commons-discovery-0.4.jar"/>
    <jar href="wsdl4j-1.6.2.jar"/>
  </resources>
  <application-desc main-class="se.testing.Application">
  </application-desc>
</jnlp>

可能有什么问题?! (这是我触摸GUI的第一个地方,我在Windows XP上。)

另外,我注意到我还有另一个AWT线程(??!?!)也挂在不同的地方:

从第1阶段开始,我就把它挂在这里:

"AWT-EventQueue-1" prio=6 tid=0x03448800 nid=0x152c runnable [0x036cf000]
    java.lang.Thread.State: RUNNABLE
        at sun.awt.windows.WComponentPeer.nativeHandleEvent(Native Method)
        at sun.awt.windows.WComponentPeer.handleEvent(Unknown Source)
        at sun.awt.windows.WWindowPeer.handleEvent(Unknown Source)
        at java.awt.Component.dispatchEventImpl(Unknown Source)
        at java.awt.Container.dispatchEventImpl(Unknown Source)
        at java.awt.Component.dispatchEvent(Unknown Source)
        at java.awt.KeyboardFocusManager.redispatchEvent(Unknown Source)
        at java.awt.DefaultKeyboardFocusManager.typeAheadAssertions(Unknown Source)
        at java.awt.DefaultKeyboardFocusManager.dispatchEvent(Unknown Source)
        at java.awt.Component.dispatchEventImpl(Unknown Source)
        at java.awt.Container.dispatchEventImpl(Unknown Source)
        at java.awt.Window.dispatchEventImpl(Unknown Source)
        at java.awt.Component.dispatchEvent(Unknown Source)
        at java.awt.EventQueue.dispatchEvent(Unknown Source)
        at java.awt.SequencedEvent.dispatch(Unknown Source)
        at java.awt.EventQueue.dispatchEvent(Unknown Source)
        at java.awt.EventDispatchThread.pumpOneEventForFilters(Unknown Source)
        at java.awt.EventDispatchThread.pumpEventsForFilter(Unknown Source)
        at java.awt.EventDispatchThread.pumpEventsForHierarchy(Unknown Source)
        at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
        at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
        at java.awt.EventDispatchThread.run(Unknown Source)

从第2阶段开始:

"AWT-EventQueue-1" prio=6 tid=0x03448800 nid=0x1638 runnable [0x036cf000]
    java.lang.Thread.State: RUNNABLE
        at sun.awt.windows.WToolkit.isWindowTranslucencySupported(Native Method)
        at com.sun.awt.AWTUtilities.isWindowTranslucencySupported(Unknown Source)
        at com.sun.awt.AWTUtilities.isTranslucencySupported(Unknown Source)
        at javax.swing.RepaintManager.updateWindows(Unknown Source)
        at javax.swing.RepaintManager.paintDirtyRegions(Unknown Source)
        at javax.swing.RepaintManager.paintDirtyRegions(Unknown Source)
        at javax.swing.RepaintManager.seqPaintDirtyRegions(Unknown Source)
        at javax.swing.SystemEventQueueUtilities$ComponentWorkRequest.run(Unknown Source)
        at java.awt.event.InvocationEvent.dispatch(Unknown Source)
        at java.awt.EventQueue.dispatchEvent(Unknown Source)
        at java.awt.EventDispatchThread.pumpOneEventForFilters(Unknown Source)
        at java.awt.EventDispatchThread.pumpEventsForFilter(Unknown Source)
        at java.awt.EventDispatchThread.pumpEventsForHierarchy(Unknown Source)
        at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
        at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
        at java.awt.EventDispatchThread.run(Unknown Source)

5 个答案:

答案 0 :(得分:0)

尝试设置f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

答案 1 :(得分:0)

如果有人找到另一种解决方案,我会直接接受!我不会蔑视当前的解决方案......


似乎只有在使用英特尔高清显卡时才会发生(我的系统是Core i3 clarkdale)。

可能的解决方案(测试!):

  • 使用Windows默认驱动程序(~vga驱动程序)
  • 新显卡

答案 2 :(得分:0)

当然看起来像图形驱动程序和java的某种问题。

查看this link to Java 2D system settings是否有帮助。

答案 3 :(得分:-1)

您是否尝试在主线程中构建GUI?事件处理线程if - 处理事件: - )

答案 4 :(得分:-1)

试试这段代码:

public static void main(String... args) {
    JFrame f = new JFrame("Test");
    f.setVisible( true );
}