多线程-synchronized详解

发布时间:2024年01月08日

1、基本作用:Java提供了一种内置的锁机制来支持原子性,同步代码块(Synchronized Block )

同步代码块包括两个部分:

  • 1、锁的对象引用。
  • 2、锁作用的代码块。

例子:

synchronized(Object){
?? ?//被保护的共享状态
}

?另外,关键字synchronized修饰的方法,整个方法体就是同步代码块,锁的对象是调用当前方法的对象;需要注意的是,静态方法以对象的字节码文件为(.class文件)作为锁对象。

2、重入

????????当某个线程尝试获取其它线程已经持有的锁时,尝试获取锁的线程就会阻塞。但是,内置锁synchronized是可重入的,如果某个线程尝试获取由自己已经持有的锁时,请求成功。

????????锁重入表示获取锁的粒度是线程。

重入原理:

(1)编写一个同步方法

public class ClassA{
    Object object = new Object();
    public void method(){
        synchronized (object){

        }
    }
}

(2)对ClassA进行编译和反编译:

编译:

????????javac ClassA.java

反编译:

? ? ? ? Javap -verbose?ClassA.class

反编译后得到如下:

?每一个对象同一时刻只能关联一个monitor,并且每一个monitor只能在同一时间被一个线程获取,当线程1获取到对象锁之后,线程2只能进入阻塞队列EntryList:

monitor锁计数器会在执行monitorenter/monitorexit指令时+1/-1

  • 当锁的计数器为0时,表示该锁没有被获取,当前线程可以获取,执行monitorenter成功。
  • 如果当前线程获取了锁之后,再次获取,即锁重入,那么在锁的计数器上+1即可,一直重入则一直累加;释放锁之后,锁计数器就-1
  • 如果锁被其他线程拿走了,那就等待释放。

?缺点:

  1. 效率低:释放锁的情况少,不能中断和设置超时。
  2. 不够灵活:加锁和释放锁的时机很单一。
  3. 无法获取锁的状态。
文章来源:https://blog.csdn.net/qq_42251944/article/details/135464088
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。