网站网站建设教程,网站描述,北京全网营销推广公司,那种做任务的网站叫什么使用范围
synchronized使用上用于同步方法或者同步代码块在锁实现上是基于对象去实现使用中用于对static修饰的便是class类锁使用中用于对非static修饰的便是当前对象锁
synchronized的优化
在jdk1.6中对synchronized做了相关的优化
锁消除
在synchronized修饰的代码块中…使用范围
synchronized使用上用于同步方法或者同步代码块在锁实现上是基于对象去实现使用中用于对static修饰的便是class类锁使用中用于对非static修饰的便是当前对象锁
synchronized的优化
在jdk1.6中对synchronized做了相关的优化
锁消除
在synchronized修饰的代码块中要是不涉及操作临界资源的情况即便你写了synchronized修饰也不会出发锁机制
锁膨胀
在一个循环中频繁的出现锁资源的获取与释放操作会带来资源的消耗于是便会将锁的范围扩大到循环的外边避免频繁的竞争和获取锁资源而导致的资源消耗 public void method(){for (int i 0; i Integer.MAX_VALUE; i) {synchronized () {// 业务代码}}}锁升级
ReentrantLock中是基于乐观锁的CAS获取线程资源。资源拿不到的情况下才会挂起线程。synchronized在jdk1.6之间完全获取不到锁的情况下立即挂起线程但是在1.6之后进行了锁的升级与优化。 无锁、匿名偏向当前对象没有作为锁的存在偏向锁当前锁资源只有一个线程频繁的获取和释放锁那么只有该线程获取锁是判断是否是同一个线程如果是线程资源拿走。如果线程不是当前自己的线程则采用基于CAS的方式尝试将偏向锁指向当前线程。如果获取不到则触发锁升级为轻量级锁也就意味着发生了锁竞争的情况。轻量级锁使用自旋锁的方式频繁的采用CAS的方式获取锁资源。这里采用的自适应自旋锁JVM更具上次的自旋结果来进行判断本次的自旋时间长短。如果成功获取锁资源资源取走。如果获取锁资源失败锁升级。重量级锁最为传统的synchronized实现方式。拿不到锁资源之间挂起线程然后进行用户态和内核态的不断切换。。。
synchronized锁的实现原理
synchronized锁是基于对象来进行实现的 关于MarkWord的内容展开示意图 从图中可以看出通过锁的标志位来进行区分锁的不同状态
synchronized锁升级的过程演示
使用之前需要导入一个依赖 dependencygroupIdorg.openjdk.jol/groupIdartifactIdjol-core/artifactIdversion0.9/version/dependency锁在默认情况下开启了偏向锁的延迟原因是因为在偏向锁升级为轻量级锁的时候会涉及到偏向锁的撤销需要等到一个安全点STW才能完成对偏向锁的撤销所以在并发的情况下就可以选择不开启偏向锁或者设置偏向锁延迟开启在JVM启动时会大量加载.class文件到内存该操作会涉及synchronized使用为了避免出现偏向锁撤销的操作。在启动初期有一个延迟5s开启偏向锁的操作。要是正常开启偏向锁那么就不会出现无锁的状态而是直接进入匿名偏向锁 变成了偏向锁 /*** author 舒一笑* date 2023/5/28*/
public class Test15 {public static void main(String[] args) throws InterruptedException {Thread.sleep(5000);Object o new Object();System.out.println(ClassLayout.parseInstance(o).toPrintable());//thread 线程偏向锁Thread thread new Thread(()-{synchronized (o){System.out.println(thread线程 ClassLayout.parseInstance(o).toPrintable());}});thread.start();// 轻量级锁 - 重量级锁synchronized (o){System.out.println(main线程 :ClassLayout.parseInstance(o).toPrintable());}}}锁转换状态示意图 LockRecord和ObjectMonitor存储的内容示意图