当前位置: 首页 / 技术干货 / 正文
好程序员Java教程之高并发锁的三种实现方法

2020-02-06

Java教程 Java培训 JavaEE 好程序员

  高并发(High Concurrency)通常是指在同一个时间点,有很多用户同时的访问同一API接口或者URL地址。高并发是随着分布式系统的问世而出现的,是Java工程师必须要掌握的技能之一。接下来的好程序员Java教程就给大家分享讲解一下高并发锁的实现方法。

好程序员

  Java

  1、乐观锁

  乐观锁使用的场景是:读不会冲突、写会冲突,同时读的频率远大于写。

  参考代码:

  public object get(Object obj){

  Object val =null;

  if(val=map.get(key)==null){

  //当map取值为null时再加锁判断

  synchronized(map){

  if(map.get(key)==null){

  set some value;

  }

  }

  }

  return map.get(key);

  }

  乐观的认为在读的时候不会产生冲突为题,在写时添加锁。所以解决的应用场景是读远大于写时的场景。

  2、String.intern()

  乐观锁不能很好的解决大量的写冲突的问题,因为很多场景下,锁只是针对某个用户或者某个订单。然而由于网络问题,用户在创建session的请求和后续的请求可能会同时到达,并行线程会优先处理后面的请求,这就催生了行锁和数据库表锁的概念,显然行锁的并发能力比表锁高很多,使用String.intern()是这种方式的具体实现。

  3、类ConcurrentHashMap

  String.inter()的缺陷是类String维护一个字符串池是放在JVM perm区的,如果用户数特别多,导致放入字符串池的String不可控,有可能导致OOM错误或者过多的Full GC。怎么样能控制锁的个数,同时减小粒度锁呢?你可以借鉴ConcurrentHashMap的方式,将需要加锁的对象分为多个bucket,每个bucket加一个锁。伪代码如下:

  

图片3

 

  类String维护了一个字符串池,当调用intern方法时,如果池已经包含一个等于此String对象的字符串(该对象由equals(Object)方法确定),则返回池中的字符串。当String 相同时,总返回同一个对象,因此就实现了对同一用户加锁。由于所的颗粒度局限于具体用户,使得系统获得最大程度的并发。

  如果你想了解更多Java高并发知识,可以来好程序员。好程序员Java培训采用创新型敏捷式教学,通过微服务构建企业级的项目,让学员每一个阶段学完后可以达到既定效果,层层加深。让学员在学习过程中养成思考问题,透彻理解,解决问题,寻求更好解决方案的职业思维,开发效率成倍增加,技术能力不断优化。

分享: 更多

上一篇:for循环相关知识梳理

下一篇:数据结构知识梳理

好程序员公众号

  • · 剖析行业发展趋势
  • · 汇聚企业项目源码

好程序员开班动态

More+
  • HTML5大前端 <高端班>

    开班时间:2021-04-12(深圳)

    开班盛况

    开班时间:2021-05-17(北京)

    开班盛况
  • 大数据+人工智能 <高端班>

    开班时间:2021-03-22(杭州)

    开班盛况

    开班时间:2021-04-26(北京)

    开班盛况
  • JavaEE分布式开发 <高端班>

    开班时间:2021-05-10(北京)

    开班盛况

    开班时间:2021-02-22(北京)

    开班盛况
  • Python人工智能+数据分析 <高端班>

    开班时间:2021-07-12(北京)

    预约报名

    开班时间:2020-09-21(上海)

    开班盛况
  • 云计算开发 <高端班>

    开班时间:2021-07-12(北京)

    预约报名

    开班时间:2019-07-22(北京)

    开班盛况
IT培训IT培训
在线咨询
IT培训IT培训
试听
IT培训IT培训
入学教程
IT培训IT培训
立即报名
IT培训

Copyright 2011-2023 北京千锋互联科技有限公司 .All Right 京ICP备12003911号-5 京公网安备 11010802035720号