1700449655
1700449656
在此段代码中,设置了一个极端条件:所有的线程在启动前都执行stop方法,虽然它是一个已过时(Deprecated)的方法,但它的运行逻辑还是正常的,况且stop方法在此处的目的并不是停止一个线程,而是设置线程为不可启用状态。想来这应该是没有问题的,但是运行结果却出现了奇怪的现象:部分线程还是启动了,也就是在某些线程(没有规律)中的start方法正常执行了。在不符合判断规则的情况下,不可启用状态的线程还是启用了。这是为什么呢?
1700449657
1700449658
这是线程启动(start方法)的一个缺陷。Thread类的stop方法会根据线程状态来判断是终结线程还是设置线程为不可运行状态,对于未启动的线程(线程状态为NEW)来说,会设置其标志位为不可启动,而其他的状态则是直接停止。stop方法的源代码如下:
1700449659
1700449660
public final void stop(){
1700449661
1700449662
if((threadStatus!=0)&&!isAlive()){
1700449663
1700449664
return;
1700449665
1700449666
}
1700449667
1700449668
stop1(new ThreadDeath());
1700449669
1700449670
}
1700449671
1700449672
private final synchronized void stop1(Throwable th){
1700449673
1700449674
/*安全检查省略*/
1700449675
1700449676
if(threadStatus!=0){
1700449677
1700449678
resume();
1700449679
1700449680
stop0(th);
1700449681
1700449682
}else{
1700449683
1700449684
if(th==null){
1700449685
1700449686
throw new NullPointerException();
1700449687
1700449688
}
1700449689
1700449690
stopBeforeStart=true;
1700449691
1700449692
throwableFromStop=th;
1700449693
1700449694
}
1700449695
1700449696
这里设置了stopBeforeStart变量,标志着是在启动前设置了停止标志,在start方法中是这样校验的:
1700449697
1700449698
public synchronized void start(){
1700449699
1700449700
//分配栈内存,启动线程,运行run方法
1700449701
1700449702
start0();
1700449703
1700449704
//在启动前设置了停止状态
[
上一页 ]
[ :1.700449655e+09 ]
[
下一页 ]