在不同线程中更改标志时,while循环未结束

用户1543221:

我的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编译器试图优化空的wh​​ile循环到它实际上停止检查“ flag”变量的程度的结果吗?有没有人提出使此工作正常进行的建议,或者是否有一些更漂亮的基于并发的方法来使主线程暂停直到keyPressed线程执行?

谢谢!

dasblinkenlight:

您需要声明该标志volatile,否则编译器可以优化您的代码并跳过对标志的读取。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章