AWT事件线程中断

时间:2011-10-04 20:38:30

标签: java multithreading swing awt

我有代码:

import java.awt.Dimension;
import java.util.Observable;
import java.util.Observer;

import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.SwingUtilities;


public class Test2 {

JFrame frame = null;
JPanel panel = null;
JButton button = null;
Task task = null;
Indicator indicator = null;
Runnable computation;

public static void main(String[] args) {
    new Test2().start();
}

public void start() {
    SwingUtilities.invokeLater(new Dialog());
}

private void process1() {
    int result = 0;

    for (int i=0; i<100000; i++) {
        result = (int) Math.ceil(++result + Math.sqrt(result));

        System.out.println("proc1 " + result);
    }
}

private void process2() {
    int result = 0;

    for (int i=0; i<100000; i++) {
        result = (int) Math.ceil(++result + Math.sqrt(result)*500);

        System.out.println("proc2 " + result);
    }
}

private class Computation implements Runnable {

    public void run() {

        process1();
        task.setProgress(2);
        process2();
        task.setProgress(3);
    }

}

private class Dialog implements Runnable {

    public Dialog() {
    }

    public void run() {
        frame = new JFrame("Test");
        panel = new JPanel();
        panel.setPreferredSize(new Dimension(300, 200));
        frame.getContentPane().add(panel);
        button = new JButton("b1");
        panel.add(button);
        indicator = new Indicator();
        task = new Task();
        task.addObserver(indicator);

        frame.pack();
        frame.setVisible(true);

        computation = new Computation();
        SwingUtilities.invokeLater(computation);
    }
}

private class Task extends Observable {

    int progress;

    public Task() {

    }

    public void setProgress(int progress) {
        this.progress = progress;
        setChanged();
        notifyObservers();
    }

    public int getProgress() {
        return progress;
    }
}

private class Indicator implements Observer {

    @Override
    public void update(Observable arg0, Object arg1) {
        button.setText(((Task)arg0).getProgress()+"");
    }
}
}

所以我有两个耗时的操作(process1和process2)。我的目标是在process1完成后,更新swing按钮(参见task.setProgress方法)。

问题在于,在process1()和process2()完成后执行更新。

1 个答案:

答案 0 :(得分:4)

  

..在process1()和process2()完成后执行更新。

请勿在EDT上执行长时间运行的任务,有关详细信息,请参阅Concurrency in Swing。实现这一目标的一种方法是使用SwingWorker


  

..如果我使用两个SwingWorkers执行process1()process2(),则执行顺序无法预测。我需要process2()跟随process1()。我怎么能得到这个?

在1 SwingWorker的{​​{3}}方法中调用这两种方法,并在适当的时间使用适当的值调用doInBackground()。 E.G。

... doInBackground() {
    setProgress(0);
    process1();
    setProgress(50);
    process2();
    setProgress(100);
}
相关问题