时间:2021-05-20
在并发编程中,synchronized关键字是常出现的角色。之前我们都称呼synchronized关键字为重量锁,但是在JDK1.6中对synchronized进行了优化,引入了偏向锁、轻量锁。本篇介绍synchronized关键字的使用方式,区别和偏向锁、轻量锁和重量锁实现原理。
先看看synchronized关键字的4种用法。
1、修饰普通方法
private synchronized void synMethod(){ }这种用法中,synchronized锁的对象实例。
2、修饰静态方法
private static synchronized void synMethod(){ }synchronized在这种情况下,锁的是当前Class类对象。
3、同步方法块
private void synMethod1(){ synchronized(this){ } } private void synMethod2(){ synchronized(ThreadTest.class){ } }synMethod1中锁对象实例;synMethod2的是当前Class类对象。
再介绍锁原理
在介绍锁原理之前,先认识一下Java对象头Mark Word,以32位为例。
锁状态
25 bit
4bit
1bit
2bit
23bit
2bit
是否偏向锁
锁标志位
轻量级锁
指向栈中锁记录的指针
0
重量级锁
指向互斥量(重量级锁)的指针
10
GC标记
空
11
偏向锁
线程ID
Epoch
对象分代年龄
1
01
无锁
对象的hashCode
对象分代年龄
0
01
上面的表格中,描述的是对象在每个锁状态时,对象头中所存储的信息。
1、偏向锁
实际环境中,线程在访问同步块时,如果没有其他线程对锁进行竞争,并且由同一个线程多次获得锁,也就是单线程运行同步代码,在这种情况下,若是每次还阻塞线程,就代表白白浪费CPU性能。这种情况下,引入了偏向锁概念。
可以使用-XX:-userBiasedLocking=false来关闭JVM偏向锁优化,默认直接进入轻量锁。
2、轻量锁
访问同步代码块时,先在当前线程的线程栈中创建一个锁记录(Lock Record)区域。
把对象头Mark Word拷贝到Lock Record中。
利用CAS尝试将对象头Mark Word中的线程指针更新为指向当前线程的指针
更新成功,则获得轻量锁。
更新失败,检查Mark Word中的指针是否指向当前线程。
如果是,则说明是锁的重入现象。执行同步代码块
如果不是,则说明此时存在竞争。需要把轻量锁膨胀为重量锁。
3、重量锁
重量锁是基于对象监视器(Monitor)来实现的。
线程在执行同步代码时,需要调用一个Monitor.enter指令。执行退出后,调用Monitor.exit指令。这里看得出,监视器具有排它性,一个时间点只能有一个线程enter成功,其他线程只能阻塞在队列中。所以这种重量锁的操作成本很高。
以上所述是小编给大家介绍的Java中的关键字synchronized详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前言在Java中,有一个常被忽略但非常重要的关键字Synchronized今天,我将详细讲解Java关键字Synchronized的所有知识,希望你们会喜欢目录
synchronized和lock的异同如下: 1、首先synchronized是java内置关键字,在jvm层面,Lock是个java类; 2、synch
一、volatile是什么volatile是Java并发编程中重要的一个关键字,被比喻为“轻量级的synchronized”,与synchronized不同的是
先看一段synchronized的详解:synchronized是java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个
在Java5以前,是用synchronized关键字来实现锁的功能。synchronized关键字可以作为方法的修饰符(同步方法),也可作用于函数内的语句(同步