synchronized底层实现及其优化

synchronized使用场景

synchronized关键字主要解决线程之同步互斥的问题,在JavaSE中HashTable,StringBuffer,Vector等,它们的底层实现的方法中都是用synchronized关键字进行了修饰。

synchronized的实现原理

synchronized关键字经过编译之后,会在同步快的前后生成monitorentr和monitorexit两个字节码指令,这两个字节码都需要实现一个reference类型的参数来指定锁定和解锁的对象。在执行monitorentr指令时首先常识获取对象的锁,如果这个对象没有锁定,那么这个线程就获取了这个锁对象,把锁的计数器进行加1。在执行monitorexit时,计数器的值就要进行减1。当计数器的值为0时,这是释放锁对象。如果获取锁对象失败,那么就要等待,直到对象锁被另一个线程所释放。

为什么synchronized是重量级的锁

当一个同步快被其他线程锁所占有,其他的线程只能处于阻塞的状态。但是JAVA中的线程是映射到操作系统的原生线程上,如果阻塞或者唤醒一个线程,则需要操作系统来进行帮助完成,还需要从用户态转到和核心态,并且转换也消耗和浪费时间。

锁优化

1.自旋锁:

自旋锁在jdk1.4的时候默认是关闭的在JDK1.6的时候默认是打开的。自旋锁避免了线程切换的开销,但是占用了处理器的时间,如果自旋锁超过默认的次数(10次)没有获取到锁,那么就处于挂起状态。
如果一个线程刚进入阻塞状态,它所需要的资源也刚好被释放,这个线程又要从阻塞状态进入运行转台这样的话,太费时了。这个时候采用自旋锁是最优的。

2.自适应自旋锁:

在JDK1.6的时候引入,自适应就是意味着自选的时间是不确定的,而是由前一次在同一个对象上的自选时间和拥有者的状态决定的。如果上一个对象成功获得了锁,并且持有锁的线程正在运行中,那么虚拟机就认为自选很可能再次成功,例如允许循环200次。如果某个锁自选很少获得成功,那么在以后获取这个琐时,直接省略自旋的过程,防止浪费处理机的时间。

3.锁粗化

我们在编写代码时,会将量的缩小同步代码块的范围,这样做的好处是,如果存在竞争,那么等待锁的线程会尽快的拿到锁对象。但是一系列连续的对象反复的对同一个对象频发的进行加锁和解锁,即使没有线程竞争,会导致不必要的性能损耗。

public String fun(String str1,String str2,String str3){
      StringBuffer buffer = new StringBuffer();
      buffer.append(str1);
      buffer.append(str2);
      buffer.append(str3);
      return buffer;
}

操作因为StringBuffer是加锁的所以,第一个append方法到最后一个append方法只需要加锁一次就行了。

4.轻量级锁

轻量级锁是在JDK1.6是引入,本意是在没有多线程竞争的前提下,减少传统重量级锁的使用使操作系统互斥量产生的性能浪费。根据HostSpot虚拟机的头部中的轻量级锁的标志位其中标志位,
01代表未锁定,00代表轻量级锁定,00重量级锁
首先如果此同步对象中没有锁对象,状态为01状态,虚拟机将为当前线程的栈帧中创建锁记录空间,用于存储对象MarkWord的拷贝,虚拟机使用CAS操作尝试将对象Mark Word的空间内容更新到栈帧所记录空间中,并将状态码改为00。如果更新失败,,则说明已有线程已经拥有了这个锁。如果有两条或者两条以上的线程争取同一个锁,那么轻量级锁就失效转换为重量级锁。

5.偏向锁

偏向锁JDk1.6引入,偏向锁就是在无竞争的情况下整个同步都清除。它偏向于第一个所得它的线程,如果在接下来的执行过程中,该锁没有被其他线程所获取,则持有偏向锁的线程永远搜不需要同步。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,826评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,968评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,234评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,562评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,611评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,482评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,271评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,166评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,608评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,814评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,926评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,644评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,249评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,866评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,991评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,063评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,871评论 2 354