我正在尝试这样做,当我按下一个按钮时,程序在一个新线程中启动一个方法。问题是,当我按下按钮时,程序就会冻结,直到方法运行完毕,就像我根本没有使用线程一样。有人知道如何解决这个问题吗?
谢谢摩根。
public Listeners()
{
Calendar.ButtonAddReminder.addActionListener(new ButtonAddListener());
}
private class ButtonAddListener implements ActionListener
{
public void actionPerformed(ActionEvent e) {
new Thread(Calendar.reminder.Reminderchecker(Calendar.reminder.addReminder(date, str))) .start();
}
}发布于 2011-09-16 20:05:00
从这一点上看,似乎Calendar.reminder.addReminder()或Calendar.reminder.Reminderchecker()中的某些东西正在花费一些时间并锁定UI,因为这就是在EDT中发生的事情。
编辑:哦,我明白了。你不是在做你认为你在做的事情。您正在当前线程中执行Reminderchecker。该方法返回的Runnable就是在新线程中执行的内容。要在线程中运行Reminderchecker,请执行以下操作:
new Thread(new Runnable() {
public void run() {
Calendar.reminder.Reminderchecker(...);
}
}).start();更好的做法是:不要像那样产生你自己的随机线程。使用有组织的并发策略,例如ExecutorService提供的策略。通过Executors类,您可以轻松地创建几个涵盖常见用途的类。
更好的是:查看SwingWorker和它的API docs。
发布于 2011-09-16 20:19:16
您需要确保所有这些都发生在新线程中:
Calendar.reminder.Reminderchecker(Calendar.reminder.addReminder(date, str ))此刻
Calendar.reminder.addReminder(date, str )和
Calendar.reminder.Reminderchecker()在构造和启动新的Thread之前,在事件调度线程上调用。
纠正此错误的最简单方法是创建一个新的Runnable对象,该对象执行所有这些步骤,然后将其传递给新线程。我猜从Reminderchecker()返回的对象本身就是一个Runnable,在这种情况下,你需要类似这样的东西:
Runnable task = new Runnable() {
public void run() {
Runnable r = Calendar.reminder.Reminderchecker(Calendar.reminder.addReminder(date, str ));
r.run();
};
new Thread(task).start();发布于 2011-09-16 20:30:16
假设您的Calendar类实现了Runnable或扩展了Thread,您不应该在启动新线程之前调用Calendar.reminder.Reminderchecker(Calendar.reminder.addReminder(date, str )),因为这会调用新线程的run()方法。
取而代之的是这样做:
public class Calendar implements Runnable {
public void run() {
this.reminder.Reminderchecker(Calendar.reminder.addReminder(date, str ));
}
}https://stackoverflow.com/questions/7444376
复制相似问题