为什么说java的synchronized 锁定代码块和synchronized锁定类对象都指的类对象?

本文探讨了Java中synchronized锁定代码块与锁定类对象的等价性,指出锁定代码块实际上是对实例对象的锁定。同时,通过示例验证了非静态同步方法等同于锁定对象。文章还讨论了同一个对象的两个同步非静态方法不能并发执行,因为它们都需要获取同一对象锁,从而形成竞争关系。
摘要由CSDN通过智能技术生成

锁定代码块等价于锁定对象

首选看一下锁定代码块的语法?

    synchronized (对象)
    {
   
        // 代码块
    }

上面的语法中的"对象",指的是实例对象,可以是this,Class.clss或者其他共享对象.所以代码块锁定的等价于对象锁定.我们甚至还可以假设一下.把上面代码的"对象"做成变量:

    public void func1(Object lock) {
    // 这个方法没有锁定,锁定的是里面的代码块

        synchronized (lock) {
   

            System.out.println("方法开始");
            try {
   
                Thread.sleep(3000);
            } catch (Exception e) {
   
                e.printStackTrace();
            }
            System.out.println("方法结束");
        }
    }

那如果我们锁住的不是lock对象,而是func1里面的代码,那无论传入的lock对象是什么,这段代码都不能并发执行了.这显然是不可能的.我们看看输出也再次证明了这个结论:

方法开始
方法开始
方法结束
方法结束

锁定非静态方法等价于锁定对象

先抛出原因:

对象的非静态 synchronized 方法被调用的时候,会先将对象锁定,类似自动调用synchronized(this).

验证:

假如我们一个进程先调用对象的非静态 synchronized 方法,然后另一个进程调用 synchronized(this).
如果第一个进程没有为对象加锁,第二个进程就能调用成功,然后两者是并行的,结论不成立
反之,第二个进程无法获得对象锁,两个进程就必须串行,结论成立

  1. 先定义共享对象
class TestSyn {
   

    public synchronized void func1() {
    // 这个方法没有锁定,锁定的是里面的代码块
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值