在学习线程的过程中,做个了一个测试,想试试synchronized加在静态方法上时的情况。我开启了2个线程,当发现静态变量 a 为0时,则会输出,商品已经售完的语句,但是我在日志中只看到一次输出,理论上应该是2输出才对吧?测试代码见下方,求大佬帮忙看看原因!
public class T1 {
public static int a = 100;
public synchronized static void ct () {
try {
for (int i = 1; i <=100 ; i++) {
if(a==0){
System.out.println("商品已经售完!");
return;
}
a--;
System.out.println(Thread.currentThread().getName()+ ": a = " + a);
}
//Thread.sleep(10000);
} catch (Exception e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
//第一个线程开始
new Thread(() ->{
T1.ct();
}).start();
//第二个线程等待第一个线程结束,理论上应该也是会输出 "商品已经售完" 才对吧?为什么日志没
//输出呢?
new Thread(() ->{
T1.ct();
}).start();
}
}