打字猴:1.700449829e+09
1700449829
1700449830 Thread.sleep(100);
1700449831
1700449832 }catch(InterruptedException e){
1700449833
1700449834 e.printStackTrace();
1700449835
1700449836 }
1700449837
1700449838 //自减
1700449839
1700449840 a—;
1700449841
1700449842 String tn=Thread.currentThread().getName();
1700449843
1700449844 System.out.println(tn+”:a=”+a);
1700449845
1700449846 }
1700449847
1700449848 }
1700449849
1700449850 }
1700449851
1700449852 MultiThread实现了Runnable接口,具备多线程能力,其中run方法中加上了synchronized代码块,表示内部是原子逻辑,它会先自增然后再自减少,按照synchronized同步代码块的规则来处理,此时无论启动多少个线程,打印出来的结果都应该是a=0,但是如果有一个正在执行的线程被stop,就会破坏这种原子逻辑,代码如下:
1700449853
1700449854 public static void main(String[]args){
1700449855
1700449856 MultiThread t=new MultiThread();
1700449857
1700449858 Thread t1=new Thread(t);
1700449859
1700449860 //启动t1线程
1700449861
1700449862 t1.start();
1700449863
1700449864 for(int i=0;i<5;i++){
1700449865
1700449866 new Thread(t).start();
1700449867
1700449868 }
1700449869
1700449870 //停止t1线程
1700449871
1700449872 t1.stop();
1700449873
1700449874 }
1700449875
1700449876 首先要说明的是所有线程共享了一个MultiThread的实例变量t,其次由于在run方法中加入了同步代码块,所以只能有一个线程进入到synchronized块中。此段代码的执行顺序如下:
1700449877
1700449878 1)线程t1启动,并执行run方法,由于没有其他线程持同步代码块的锁,所以t1线程执行自加后执行到sleep方法即开始休眠,此时a=1。
[ 上一页 ]  [ :1.700449829e+09 ]  [ 下一页 ]