2013-06-21 3 views
0

SwingWorker이 백그라운드에서 실행 중입니다. 그것이 작동 후 몇 가지. 기다릴거야. 사용자가 버튼을 누를 때, MyListener은 이 호출되고 작업자가 잠에서 깨어나서 작업을 계속합니다. 그것은 내가 생각했던 것처럼 작동하지 않습니다 . 맨 아래에 예외가 발생합니다. 내가 잘못한 것을 나에게 에게 말해주세요.대기중인 SwingWorker를 깨우는 방법?

MyWorker worker = new MyWorker();  

class MyListener implements ActionListener { 

    @Override 
    public void actionPerformed (ActionEvent e) { 

     //DO some stuff and wake up worker 
     worker.notify();   
    } 
} 

class MyWorker extends SwingWorker { 

    boolean _work = true; 

    @Override 
    protected Object doInBackground() throws Exception { 
     System.out.println ("in myWorker"); 
     while (_work == true) { 

      //DO some stuff here 
      wait();   
     } 
     return null; 
    } 
} 

예외 :

Exception in thread "AWT-EventQueue-0" java.lang.IllegalMonitorStateException 
    at java.lang.Object.notify(Native Method) 
    at worker.Worker$2.actionPerformed(Worker.java:54) 
    at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:2018) 
    at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2341) 
    at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:402) 
    at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:259) 
    at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:252) 
    at java.awt.Component.processMouseEvent(Component.java:6505) 
    at javax.swing.JComponent.processMouseEvent(JComponent.java:3321) 
    at java.awt.Component.processEvent(Component.java:6270) 
    at java.awt.Container.processEvent(Container.java:2229) 
    at java.awt.Component.dispatchEventImpl(Component.java:4861) 
    at java.awt.Container.dispatchEventImpl(Container.java:2287) 
    at java.awt.Component.dispatchEvent(Component.java:4687) 
    at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4832) 
    at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4492) 
    at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4422) 
    at java.awt.Container.dispatchEventImpl(Container.java:2273) 
    at java.awt.Window.dispatchEventImpl(Window.java:2713) 
    at java.awt.Component.dispatchEvent(Component.java:4687) 
    at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:707) 
    at java.awt.EventQueue.access$000(EventQueue.java:101) 
    at java.awt.EventQueue$3.run(EventQueue.java:666) 
    at java.awt.EventQueue$3.run(EventQueue.java:664) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76) 
    at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:87) 
    at java.awt.EventQueue$4.run(EventQueue.java:680) 
    at java.awt.EventQueue$4.run(EventQueue.java:678) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76) 
    at java.awt.EventQueue.dispatchEvent(EventQueue.java:677) 
    at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:211) 
    at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:128) 
    at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:117) 
    at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:113) 
    at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:105) 
    at java.awt.EventDispatchThread.run(EventDispatchThread.java:90) 

답변

2

당신은 notify 호출 주위에 동기화 된 블록을 추가해야합니다.

synchronized (worker) { 
    worker.notify(); 
} 

지금 갖는 당신은 일반적으로 잘못된 예를

+0

감사 데의 가능성을 감소 모니터 잠금으로 인스턴스 변수를 사용하여 대신 (다른 것들 사이)와 같은 static final 잠금 개체를 사용하여 낙심되고 있다고 말했다 당신. 그 동기화는 예외를 수정했습니다. 어떤 이유로 근로자는 여전히 깨어나지 않습니다. 나는 아직도 뭔가를 놓치고 있습니까? – tadpole

+0

작업자에서 동일한 작업을 수행합니다 (호출 대기를 제외하고). 작업이 이미 동일한 예외를 발생 시켰지만, 작업자의 작업 방식으로 인해 아직 보지 못했을 것입니다. – MadProgrammer

+0

맞습니다. 다시 한번 감사드립니다. – tadpole

관련 문제