java – 当标志在不同的线程中更改时,循环不结束

前端之家收集整理的这篇文章主要介绍了java – 当标志在不同的线程中更改时,循环不结束前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
参见英文答案 > Loop doesn’t see changed value without a print statement1个
我在我的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线程执行?

谢谢!

解决方法@H_502_15@
您需要声明标志 volatile,否则编译器可以优化您的代码并跳过标志的读取.

猜你在找的Java相关文章