synchronized修饰静态方法和非静态方法

static的方法属于类方法,它属于这个Class(注意:这里的Class不是指Class的某个具体对象),那么

static获取到的锁,是属于类的锁

非static方法获取到的锁,是属于当前对象的锁

非static

同一个对象,在两个线程中分别访问该对象的两个同步方法----》

因为锁针对的是对象,当对象调用一个synchronized方法时,其他同步方法需要等待其执行结束并释放锁后才能执行

不同对象,在两个线程中调用同一个同步方法----》

不会产生互斥

static

用类直接在两个线程中调用两个不同的同步方法----》

因为对静态对象加锁实际上对类(.class)加锁,类对象只有一个,因此同步方法之间一定是互斥的

用一个类的静态对象在两个线程中调用静态方法或非静态方法----》

因为是一个对象调用,互斥的

一个对象在两个线程中分别调用一个静态同步方法和一个非静态同步方法----》

虽然是一个对象调用,但是两个方法的锁类型不同,调用的静态方法实际上是类对象在调用,即这两个方法产生的并不是同一个对象锁,因此不会互斥,会并发执行

pulbic class Something(){

    public synchronized void isSyncA(){}
    
    public synchronized void isSyncB(){}
    
    public static synchronized void cSyncA(){}
    
    public static synchronized void cSyncB(){}

}

现又Something的两个实例,x和y

a. x.isSyncA()与 x.isSyncB()--------------------互斥(同一个实例)

b. x.isSyncA()与 y.isSyncA()--------------------互相不影响(不同实例)

c. x.cSyncA()与 y.cSyncB()----------------------互相不影响(不同实例之间不会被限制)

d. x.isSyncA()与 Something.cSyncA()--------互相不影响(锁不同)

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值