Java:人为制造一个锁竞争

代码示例展示了在Java中线程如何争夺同步方法的锁。当移除`Thread.sleep(1000)`时,可能无法捕捉到线程的真实状态,因为线程可能还未开始执行。加上这行代码,确保了线程状态的可见性,可能的输出是线程A处于BLOCKED等待锁,而线程B处于RUNNABLE状态,或者反之。
摘要由CSDN通过智能技术生成

目录

先上代码:

运行结果:

其中,如果不要那一句:Thread.sleep(1000);


先上代码:


public class test {

    @SneakyThrows
    @Test
    public void blockedTest() {
        Thread a = new Thread(new Runnable() {
            @Override
            public void run() {
                testMethod();
            }
        }, "a");
        Thread b = new Thread(new Runnable() {
            @Override
            public void run() {
                testMethod();
            }
        }, "b");
        a.start();
        Thread.sleep(1000);//注意这句!
        //a.join(); //这句会让主线程 堵塞在这里,知道a执行完毕了,才继续往下走
        b.start();
        System.out.println(a.getName() + ":" + a.getState()); // 输出?
        System.out.println(b.getName() + ":" + b.getState()); // 输出?
    }
    // 同步⽅法争夺锁
    private synchronized void testMethod() {
        try {
            Thread.sleep(2000L);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}

运行结果:

其中,如果不要那一句:Thread.sleep(1000);

该代码可能会输出以下两种结果之一:

结果 1: a:BLOCKED b:RUNNABLE

结果 2: a:RUNNABLE b:BLOCKED

因为:测试⽅法的main线程只保证了a,b两个线程调⽤start()⽅法(转化为RUNNABLE状态),还没等两个线程真正开始争夺锁,就已经打印此时两个线程的状态(RUNNABLE)了。所以要加一个 Thread.sleep(1000);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值