Synchronize原理
1 普通方法上
2 静态方法上
修饰静态方法内置锁是当前的Class字节码对象
修饰普通方法内置锁是当前类的实例
原理与使用:
从字节码层面解释:
执行同步代码块
monitorenter
synchronized( ){
}
monitorexit
任何对象都可以作为锁,那么锁信息有存在对象的什么地方呢?
存在对象头中
对象头中的信息 Mark Word Class Metadata Address ArrayLength
Mark Word 存储的是哈希值 锁信息 空间利用率很高的
任何对象都可以作为锁,那么锁信息又存在对象的什么地方呢?
存在对象头中
对象头中的信息: Mark Word Class MetaData Address
jdk1.6之后 引入了
偏向锁: 每次获取锁和释放锁会浪费资源。很多情况下,竞争者不是由多个线程,而是由一个线程在使用。
当一个线程进来时候,找对象头查看是否是偏向锁。偏向锁的Mark Word 字段会记录一些信息 :线程id Epoch 对象分代年龄信息 是否是偏向锁 锁标志位
检查锁标志位是否是偏向锁,接着会检查线程的id如果和当前线程id是一致(第一次直接进来)。第二次进来时候 接着运行同步代码块(没有锁的获取和释放)。偏向锁获取时候,没有撤销。等到有竞争时候 才有释放的机制。 场景:只有一个线程访问代码块会大大提高性能。(多个线程会降低性能)
轻量级锁:
首先栈帧:
虚拟机栈里面存储的是一个个栈帧,每个方法执行都会存储一个栈帧。每个方法执行都会执行栈帧的进栈出栈。
复制Mark Word 到虚拟机栈中
竞争成功之后会将锁的标志位改成轻量级锁,然后执行同步体。
其他线程也是复制Mark Word到虚拟机中
修改Mark Word,发现已经被别的线程获得了锁,所以修改不成功。然后不停的修改。直到第一个线程把锁释放了才OK
第一个线程执行完毕,第二个获取锁之后,会升级为重量级锁(普遍意义上的synchronize),线程会阻塞。
轻量级锁用到了自旋概念。好处:多个线程可以同时
关于单例模式结合Synchronize
单例模式与线程安全问题
饿汉式是没有线程安全问题的
懒汉式是有线程安全问题的
缩小同步代码块的范围,只有在创建时候才有写的操作 其他的都是读的操作没有线程安全问题
在会出现线程安全问题地方加一个synchronize,锁当前的代码 包裹起来
这样其实还是有问题的,双重加锁,再来一个验空。
这样视乎是一个没有问题,重排序问题。
有可能先执行下面的 在执行上面的这样的重排序问题(没法演示)
package com.toov5.threadTest;
public class DoubleLock { private static volatile DoubleLock doubleLock; //防止重排序 private DoubleLock(){ }
public static DoubleLock getInstance(){ //比较饿汉模式而言的,如果在这一行加锁,效率势必会比较低 利用同步代码块
//自旋while(true)
if (doubleLock == null){ //判断一下 如果为null时候 这种情况下才会去创建对象
synchronized (DoubleLock.class){ //静态的用 字节码文件
if (doubleLock==null) { //上锁完了之后 可能没有创建完毕 所以要判断一下 但是 重排序时候 可能会导致 对象可能创建多次
//所以加volitile关键字 (单线程是不会产生重排序问题)
doubleLock=new DoubleLock();
}
} }
return doubleLock; //不为空的话 会直接返回呀 多个线程去创建时候 才有有安全塞问题
} public static void main(String[] args) {
DoubleLock doubleLock1 = DoubleLock.getInstance();
DoubleLock doubleLock2 = DoubleLock.getInstance();
System.out.println(doubleLock1==doubleLock2);
} }
Synchronize原理的更多相关文章
- Linux内核同步 - RCU synchronize原理分析
RCU(Read-Copy Update)是Linux内核比较成熟的新型读写锁,具有较高的读写并发性能,常常用在需要互斥的性能关键路径.在kernel中,rcu有tiny rcu和tree rcu两种 ...
- 深入分析Synchronized原理(阿里面试题)
还有一篇 讲解lock的实现原理,参考:解决多线程安全问题-无非两个方法synchronized和lock 具体原理以及如何 获取锁AQS算法 (百度-美团) 记得开始学习Java的时候,一遇到多线程 ...
- Linux内核同步机制--转发自蜗窝科技
Linux内核同步机制之(一):原子操作 http://www.wowotech.net/linux_kenrel/atomic.html 一.源由 我们的程序逻辑经常遇到这样的操作序列: 1.读一个 ...
- Suspend to RAM和Suspend to Idle分析,以及在HiKey上性能对比【转】
转自:https://www.cnblogs.com/arnoldlu/p/6253665.html 测试环境:AOSP 7.1.1+Kernel 4.4.17 HW:HiKey Ubuntu 14. ...
- java对象详解
java对象及线程详解 内存布局 普通对象布局 数组的内存布局 内部类的内存布局 对象分解 对象头-mark word(8字节) 实例数据 对齐填充(可选) java锁分析 volatile关键字 v ...
- delphi 线程教学第二节:在线程时空中操作界面(UI)
第二节:在线程时空中操作界面(UI) 1.为什么要用 TThread ? TThread 基于操作系统的线程函数封装,隐藏了诸多繁琐的细节. 适合于大部分情况多线程任务的实现.这个理由足够了吧 ...
- synchronize 关键字原理
众所周知 synchronized 关键字是解决并发问题常用解决方案,有以下三种使用方式: 同步普通方法,锁的是当前对象. 同步静态方法,锁的是当前 Class 对象. 同步块,锁的是 () 中的对象 ...
- Java 并发机制底层实现 —— volatile 原理、synchronize 锁优化机制
本书部分摘自<Java 并发编程的艺术> 概述 相信大家都很熟悉如何使用 Java 编写处理并发的代码,也知道 Java 代码在编译后变成 Class 字节码,字节码被类加载器加载到 JV ...
- Delphi:与VCL同步(Synchronize()、用消息来同步)
看本文时,可以同时参考:Delphi中线程类 TThread实现多线程编程(事件.临界区.Synchronize.WaitFor……) 先说一下RTL和VCL RTL(Run-Time library ...
随机推荐
- spring中关于FeignClient的错误 QueryParam.value() was empty on parameter 1
现创建一个feignClient的接口,在其他服务调用改client时发现服务启动失败错误日志如下: org.springframework.beans.factory.BeanCreationExc ...
- 《程序员级别鉴定书》 ----中级.NET开发者
面向接口.面向对象和面向方面编程区别 面向接口编程 是面向对象编程体系中的思想精髓之一 (博客园文章链接面向接口编程详解(一)——思想基础) 面向接口编程 接口是一组规则集合 面向对象编程 对具有相同 ...
- zoj3659(经典并查集)
这种思想很经典. 从最小的边选择,那么可以知道的是,在除去这条边的另外两个联通块,选其中一块中的点做为源点到另一块所得到的费用和. 如果你已经知道了这两个联通块内部选一个点时的最大费用和.那么这题就可 ...
- JavaWeb开发的一系列可能的配置
最近电脑硬盘坏了Orz...,重装了.唉!软件什么的都要重新装,重新设置,好麻烦! 我决定写下重装javaweb开发环境的过程 1.Java的安装,配置 https://www.runoob.com/ ...
- (转)SPDY
SPDY:Google开发的基于传输控制协议(TCP)的应用层协议,目前已经被用于Google Chrome浏览器中来访问Google的SSL加密服务.SPDY并不是一种用于替代HTTP的协议,而是对 ...
- winsxs清理
win7的网友经常问:C:Windowswinsxs文件夹下是什么文件,可以删除吗? 答案是不建议你删除的,如果你特别想删除的话我推荐你一个工具. 本人亲测系统正常运行. 可以为C盘剩下将近4G空间 ...
- 使用synergyc共享键鼠
通常情况下我们经常同时操作两台或者多台电脑, 这样就会存在多个键盘鼠标来回切换的问题. 那么我们主要的目标就是怎么在多个电脑上共享一套键盘鼠标,而且可以轻松的来回切换呢. 网上有很多的解决方案,这里我 ...
- Setting IE11 with Group Policy Preferences
一.Setting Home Page with Group Policy Preferences 1.Open the Group Policy Management Console and cre ...
- 页面的日志服务 web页面渲染 服务 ; 服务耦合带来的问题
情景: 虽然对web服务做了3节点的负载均衡,但是由于埋点数据的落盘的代码也在相同服务器上,导致当flume处理日志的吞吐量达到瓶颈时,3节点的请求积压,挤占服务器资源,导致接口数据处理迟缓,页面加载 ...
- mysql主从同步因断电产生的不能同步问题
偶尔因为断电导致mysql slave 出现复制错误“Could not parse relay log event entry” Could not parse relay log event en ...