【java】怎么理解不同对象实例的对象锁是互不干扰的

在Java中,synchronized关键字用于实现线程同步,它可以作用于实例方法、静态方法以及代码块。当synchronized应用于实例方法或实例变量时,它创建的是一个对象锁,这个锁是与特定的对象实例关联的。因此,每个对象实例都有其自己的锁。

这里的关键点在于,对象锁是绑定到特定对象实例上的。这意味着对于不同的对象实例,即使它们属于同一个类,它们各自拥有独立的对象锁。当一个线程获取了一个对象实例的锁并正在执行synchronized方法或代码块时,其他试图访问该对象实例的synchronized方法或代码块的线程会被阻塞,直到第一个线程释放锁。

然而,如果另一个线程尝试访问另一个对象实例的synchronized方法或代码块,它不会被阻塞,因为每个对象实例的锁是独立的。这解释了为什么说“不同对象实例的对象锁是互不干扰的”。

例如,考虑以下类定义:

public class MyClass {
    public synchronized void method() {
        // 执行一些操作
    }
}

如果有两个MyClass的实例obj1和obj2,那么线程A可以调用obj1.method(),同时线程B可以调用obj2.method(),两者互不影响,因为它们分别持有obj1和obj2的锁。只有当线程A尝试再次调用obj1.method()时,它才会被阻塞,直到它自己释放obj1的锁。

这种机制使得在多线程环境中,可以有效地控制对特定对象实例的访问,而不会影响到其他对象实例的并发处理。

  • 10
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值