newcih 2016-07-16 23:26 采纳率: 0%
浏览 796

关于Java 线程的一个问题

前几天,在敲到一个代码,碰到如下情况:

        @Override
                public void run()
                {
                        while(true)        
                        {
// 注释句在此                        System.out.println(flag);
                                        if (flag)        
                                        {
                                                System.out.println("flag is true");        
                                                // 当标识位为true时,执行到这里,转为false
                                                flag = false;
                                        }
                        }
                }

情况是,我在外部改变flag的值,每隔0.5秒就在外部将flag设置为true。结果这段代码中注释句去掉注释的话,会有"flag is true"的输出,但是注释加上的话,就永远不会输出"flag is true"
有谁可以给出个合理解释吗?
全部代码如下:

class MyThread extends Thread
{
        // 设置标识位
        private boolean flag = false;
        public void setFlag()
        {
                flag = true;        
        }
        // 线程执行
        @Override
                public void run()
                {
                        while(true)        
                        {
//                                        System.out.println(flag);
                                        if (flag)        
                                        {
                                                System.out.println("flag is true");        
                                                // 当标识位为true时,执行到这里,转为false
                                                flag = false;
                                        }
                        }
                }

        public static void main(String[] args)
        {
                MyThread t = new MyThread();
                t.start();
                // 每隔0.5秒设置标识位为true
                while (true)
                {
                        try{
                                Thread.sleep(500);        
                        } catch (InterruptedException e)        
                        {}

                        t.setFlag();
                }
        }
}


  • 写回答

1条回答 默认 最新

  • 毕小宝 博客专家认证 2016-07-17 02:30
    关注

    根本原因不是这行的代码的问题,而是你的run代码中while(true)循环的太频繁了,而flag变动时间确实间隔500ms的。
    所以是频率上来讲,注释掉的这行每次打印flag的时候都可能为false,所以需要改下Thread的run的方法,也sleep一段时间就能看到交替打印的情况了。

     public void run() {
            while (true) {
                System.out.println(flag);
                if (flag) {
                    System.out.println("flag is true");
                    // 当标识位为true时,执行到这里,转为false
                    flag = false;
                }
    
                try {
                    Thread.sleep(500);
                } catch (InterruptedException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
        }
    

    打印结果为:

     false
    true
    flag is true
    true
    flag is true
    true
    flag is true
    false
    flag is true
    false
    flag is true
    false
    flag is true
    
    评论

报告相同问题?

悬赏问题

  • ¥100 求三轴之间相互配合画圆以及直线的算法
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 自己瞎改改,结果现在又运行不了了
  • ¥15 链式存储应该如何解决
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站