Java高并发 Synchronized详解(三)

1.1、synchronized的性质

可重入:指的是同一个线程的外层函数获得锁后,内层函数可以直接再次获取该锁
好处:避免死锁,提升封装性
粒度:线程而非调用(用三种情况来说明和pthread的区别)

情况一:证明同一个方法是可重入的

package Synchronized.Three;

public class First {
    int a = 0;
    public static void main(String[] args){
        First f = new First();
        f.method1();
    }
    private synchronized void method1() {
        System.out.println("This is method1:a = "+a);
        if(a==0){
            a++;
            method1();
        }
    }
}

This is method1:a = 0
This is method1:a = 1

、、证明了同一方法的可重入性,method()方法获取了锁,所以可以递归执行。

情况二:证明可重入不要求是同一个方法

package Synchronized.Three;

public class Second {
    public synchronized void method1(){
        System.out.println("This is method1!");
        method2();
    }
    public synchronized void method2(){
        System.out.println("This is method2!");
    }
    public static void main(){
        Second s = new Second();
        s.method1();
    }
}

This is method1!
This is method2!

情况三:证明可重入不要求是同一个类中

package Synchronized.Three;

public class three {
    public synchronized void method(){
        System.out.println("I'm father-method!");
    }
}
class three_son extends three{
    public synchronized void method(){
        System.out.println("I'm son-method!");
        super.method();
    }

    public static void main(String[] args) {
        three_son ts=new three_son();
        ts.method();
    }
}

I’m son-method!
I’m father-method!

上述证明了Java中synchronized关键字粒度是线程范围内的,不是调度范围内的。
也就是说,在一个线程中,如果他已经拿到了一把锁,而且想再次使用这把锁去访问其他的方法,并且要访问的方法需要的锁,就是我手中的这把锁,那么就依据可重入性,不需要再次显式地释放锁,可以直接访问该方法。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值