1700449879
1700449880
2)JVM又启动了5个线程,也同时运行run方法,由于synchronized关键字的阻塞作用,这5个线程不能执行自增和自减操作,等待t1线程锁释放。
1700449881
1700449882
3)主线程执行了t1.stop方法,终止了t1线程,注意,由于a变量是所有线程共享的,所以其他5个线程获得的a变量也是1。
1700449883
1700449884
4)其他5个线程依次获得CPU执行机会,打印出a值。
1700449885
1700449886
分析了这么多,相信读者也明白了输出的结果,结果如下:
1700449887
1700449888
Thread-5:a=1
1700449889
1700449890
Thread-4:a=1
1700449891
1700449892
Thread-3:a=1
1700449893
1700449894
Thread-2:a=1
1700449895
1700449896
Thread-1:a=1
1700449897
1700449898
原本期望synchronized同步代码块中的逻辑都是原子逻辑,不受外界线程的干扰,但是结果却出现原子逻辑被破坏的情况,这也是stop方法被废弃的一个重要原因:破坏了原子逻辑。
1700449899
1700449900
既然终止一个线程不能使用stop方法,那怎样才能终止一个正在运行的线程呢?答案也很简单,使用自定义的标志位决定线程的执行情况,代码如下:
1700449901
1700449902
class SafeStopThread extends Thread{
1700449903
1700449904
//此变量必须加上volatile
1700449905
1700449906
private volatile boolean stop=false;
1700449907
1700449908
@Override
1700449909
1700449910
public void run(){
1700449911
1700449912
//判断线程体是否运行
1700449913
1700449914
while(stop){
1700449915
1700449916
//Do Something
1700449917
1700449918
}
1700449919
1700449920
}
1700449921
1700449922
//线程终止
1700449923
1700449924
public void terminate(){
1700449925
1700449926
stop=true;
1700449927
1700449928
}
[
上一页 ]
[ :1.700449879e+09 ]
[
下一页 ]