码迷,mamicode.com
首页 > 其他好文 > 详细

一个经典的并发导致异常的场景

时间:2018-06-03 00:01:33      阅读:169      评论:0      收藏:0      [点我收藏+]

标签:interrupt   extends   补充   休息   exception   number   经典的   str   执行   

源码:

package lsh.concurrency.examples;

public class Novisibility {
    private static boolean ready;
    private static int number;
    private static int count = 0;
    
    private static class ReaderThread extends Thread{
        @Override
        public void run(){
            while(!ready){
                count++;
                Thread.yield();
                try {
                    Thread.sleep(1000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                System.out.println("count= "+count+"; ready= "+ready +" ;number= "+number);
            }
        }
    }
    
    public static void main(String[] args) {
            new ReaderThread().start();
            number = 42;
            try {
                System.out.println("开始休息前, ready= "+ready);
                Thread.sleep(5000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            ready = true;
            System.out.println("休息够了, ready = "+ready );
    }

}

执行结果:

开始休息前, ready= false
count= 1; ready= false ;number= 42
count= 2; ready= false ;number= 42
count= 3; ready= false ;number= 42
count= 4; ready= false ;number= 42
休息够了, ready = true
count= 5; ready= true ;number= 42

特别留意最后一行里的ready,值为 true。while进入循环的条件明明是ready = false,但是最后一个输出结果怎么是true?

ps. 不是每次输出结果都会像上面那样。

 

 

原因分析:

while循环最后1秒的时候,主线程里的, ready = true; 这行代码先于子线程里while循环语句的输出。故主线程先修改了ready的值为true,等到子线程再次去读ready的值时(已经执行完了while的循环条件判断,判断时时ready的值为false),第二次读ready得到的值已经是true了。

 

 

补充:如果在while循环的输出之前,将ready = true时的值保存到一个文件里,会发现难易拿到ready的值,因为此时ready的值仍为false; 而如果在while循环的输出之后,对ready = true时,将其值保存到一个文件里,是一件相对容易的事情,因为此时ready值已经为true。

一个经典的并发导致异常的场景

标签:interrupt   extends   补充   休息   exception   number   经典的   str   执行   

原文地址:https://www.cnblogs.com/InformationGod/p/9127477.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!