这是一篇测试文章

一、分析下面程序输出:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
/**

  • 分析一下这个程序的输出
  • @author mashibing
    */

package yxxy.c_005;

public class T implements Runnable {

private int count = 10;
 
public synchronized void run() {
    count--;
    System.out.println(Thread.currentThread().getName() + " count = " + count);
}
 
public static void main(String[] args) {
    T t = new T();
    for(int i=0; i<5; i++) {
        new Thread(t, "THREAD" + i).start();
    }
}

}
1
2
3
4
5
THREAD0 count = 9
THREAD4 count = 8
THREAD1 count = 7
THREAD3 count = 6
THREAD2 count = 5
分析:

启动了5个线程,thread0先拿到这把锁,开始执行,thread1-4都在等待准备抢这把锁;thread0执行完之后,释放锁;thread4率先抢到了这把锁,开始执行;执行完之后thread1又抢到了这把锁,开始执行....;
所以看到每次线程访问一次,count-1;而且thread执行的先后顺序每次执行的结果不同,因为你不知道哪个线程先执行了;
二、对比上一个程序,分析这个程序的输出:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
/**

  • 对比上面一个小程序,分析一下这个程序的输出
  • @author mashibing
    */

package yxxy.c_006;

public class T implements Runnable {

private int count = 10;
posted @ 2021-05-27 13:42  8023渡劫  阅读(35)  评论(0)    收藏  举报