Java synchronized阻塞的同步队列现象分析

本文探讨Java中synchronized关键字导致的线程进入同步队列的现象,详细分析了线程如何从BLOCKED状态到尝试获取锁的过程。尽管线程请求同步的顺序是1-9,但实际获取锁的顺序却是9-1,揭示了锁释放和获取的非直观行为。
public class Singleton {


    public static void main(String[] args) throws InterruptedException {

        for (int i=0; i<10; i++){
            new Thread(new QueueThread()).start();
            Thread.sleep(10);
        }

    }

    static class QueueThread implements Runnable{

        @Override
        public void run() {
            System.out.println(Thread.currentThread().getName() + " is running...");
            synchronized (QueueThread.class){
                System.out.println(Thread.currentThread().getName() + " has got lock...");
                try {
                    Thread.sleep(500);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }
    }


}


运行结果:
Thread-0 is running...
Thread-0 has got lock...
Thread-1 is running...
Thread-2 is running...
Thread-3 is running...
Thread-4 is running...
Thread-5 is running...
Thread-6 is running...
Thread-7 is running...
Thread-8 is running...
Thread-9 is running...
Thread-9 has got lock...
Thread-8 has got lock...
Thread-7 has got lock...
Thread-6 has got lock...
Thread-5 has got lock...
Thread-4 has got lock...
Thread-3 has got lock...
Thread-2 has got lock...
Thread-1 has got lock...

Process finished with exit code 0

任意线程对同步块的访问,首先要获取其锁对象的监视器,,如果获取失败(当前锁被其他线程持有,并未释放),则该线程进入同步队列,线程的状态变成BLOCKED,当访问该锁对象的前驱(获得了锁的线程)释放了锁,则该释放操作会唤醒阻塞在同步队列中的线程,使其重新尝试对监视器的获取。

分析上述代码的的打印结果,可以知道,尝试请求同步块的线程次序依次是Thread 1-9,而后续成功获得锁的线程次序却是Thread 9-1,难道不是队列中排在前面的线程,先获取释放的锁吗??

 

 

 

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值