我的Java程序的main方法中运行着while循环。该循环应该一直运行,直到在程序的keyPressed方法中将布尔标志变量设置为true为止(我将程序作为KeyListener添加到JFrame中)。
import java.awt.event.KeyEvent;
import java.awt.event.KeyListener;
import javax.swing.JFrame;
public class ThreadWhile implements KeyListener {
private boolean flag = false;
public static void main(String[] args) {
//Set up key listening on a dummy JFrame
JFrame frame = new JFrame("Key Detector 9000");
frame.setVisible(true);
ThreadWhile tw = new ThreadWhile();
frame.addKeyListener(tw);
System.out.println("Looping until flag becomes true...");
while(!tw.flag) {
//Commenting the println out makes the loop run forever!
System.out.println(tw.flag);
}
System.out.println("Flag is true, so loop terminated.");
System.exit(0);
}
public void keyPressed(KeyEvent e) {
flag = true;
System.out.println("flag: " + flag);
}
public void keyReleased(KeyEvent e) {}
public void keyTyped(KeyEvent e) {}
}
据我了解,keyPressed方法是在自己的线程中执行的,因此,当我敲击键时,变量'flag'应该设置为true,并且main方法中运行的while循环应该结束。
但是,即使我看到'flag'变量被正确设置为true,当我运行该程序时,循环也会永远运行!奇怪的是,如果我在while循环中插入'flag'变量的快速System.out.println回显,则程序可以正常运行,但是显然我不想在循环中打印任何内容。
我猜这个问题可能是Java编译器试图优化空的while循环到它实际上停止检查“ flag”变量的程度的结果吗?有没有人提出使此工作正常进行的建议,或者是否有一些更漂亮的基于并发的方法来使主线程暂停直到keyPressed线程执行?
谢谢!
您需要声明该标志volatile
,否则编译器可以优化您的代码并跳过对标志的读取。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句