打字猴:1.700450329e+09
1700450329
1700450330 while(loops++<value){
1700450331
1700450332 //共享资源清零
1700450333
1700450334 UnsafeThread ut=new UnsafeThread();
1700450335
1700450336 for(int i=0;i<value;i++){
1700450337
1700450338 new Thread(ut).start();
1700450339
1700450340 }
1700450341
1700450342 //先等15毫秒,等待活动线程数量成为1
1700450343
1700450344 do{
1700450345
1700450346 Thread.sleep(15);
1700450347
1700450348 }while(tg.activeCount()!=1);
1700450349
1700450350 //检查实际值与理论值是否一致
1700450351
1700450352 if(ut.getCount()!=value){
1700450353
1700450354 //出现线程不安全的情况
1700450355
1700450356 System.out.println(“循环到第”+loops+“遍,出现线程不安全情况”);
1700450357
1700450358 System.out.println(“此时,count=”+ut.getCount());
1700450359
1700450360 System.exit(0);
1700450361
1700450362 }
1700450363
1700450364 }
1700450365
1700450366 }
1700450367
1700450368 这是一段设计很巧妙的程序,要让volatile变量“出点丑”还是需要花点功夫的。此段程序的运行逻辑如下:
1700450369
1700450370 启动100个线程,修改共享资源count的值。
1700450371
1700450372 暂停15毫秒,观察活动线程数是否为1(即只剩下主线程在运行),若不为1,则再等待15毫秒。
1700450373
1700450374 判断共享资源是否是不安全的,即实际值与理想值是否相同,若不相同,则发现目标,此时count的值为脏数据。
1700450375
1700450376 如果没有找到,继续循环,直到达到最大循环次数为止。运行结果如下:
1700450377
1700450378 循环到第247遍,出现线程不安全情况
[ 上一页 ]  [ :1.700450329e+09 ]  [ 下一页 ]