当前位置: 首页 > news >正文

广州软件园 网站建设免费ppt模板下载 知乎

广州软件园 网站建设,免费ppt模板下载 知乎,wordpress服务器版,企业官方网站模板下载项目场景: 并发的应用场景,在开发过程会经常遇到。 例如:服务应用启动后,需要简单统计接口的总访问量;实时更新订单状态,成交总额。 问题描述: 比如统计接口访问次数,如下的实现&a…

项目场景:

并发的应用场景,在开发过程会经常遇到。
例如:服务应用启动后,需要简单统计接口的总访问量;实时更新订单状态,成交总额。


问题描述:

比如统计接口访问次数,如下的实现,在并发访问下,统计是不准确的 。

		private int viewCount = 0;private void addViewCount(){viewCount++;}

比如A、B两个线程同时访问,各自从JVM主存中加载变量viewCount到线程内存里viewCount的值都是0,各自+1,更新会JVM主存的也是1。实际A、B执行完毕后,JVM的值应该是2才对。


解决方案:

在这里插入图片描述
并发问题解决,实际有2种方式:有锁、无锁。
有锁的就是关键字synchronized,以及可重入锁ReentrantLock。
无锁的,就是局部变量、不可变对象、CAS原子类、ThreadLocal,共四种。


具体解决方案分析:

一.无锁方式

1.局部变量

    /*** 局部变量,多线程更新count的时候,各自在线程内存中创建i变量。*/public void localParam(){int count = 0;/*本次处理业务,统计*/count++;System.out.println(count);}

2.不可变对象

车辆位置实时更新,传统的setY,setY,在并发过程会出差错。定义一个final localtion类,并且构造函数直接初始化x,y。
/*** 车辆位置经纬度值*/
public final class Location {private final double x;private final double y;public Location(double x, double y) {this.x = x;this.y = y;}
}
同时定义一个traker类,来存储多个车辆的位置信息,更新的时候直接用新的location位置类,去update ConcurrentHashMap。
/*** 不可变类,实现并发更新安全* 通过每次更新位置,直接初始化一个全新的location,然后set到车辆位置map中*/
public class CarLocationTracker {/*** 车辆编码对应车辆位置信息map* ConcurrentHashMap,是利用CAS+synchronized来保证并发安全*/private Map<String, Location> locationMap = new ConcurrentHashMap<>();/*** 更新车辆位置** @param carCode     车辆编码* @param newLocation 车辆新位置*/public void updateLocation(String carCode, Location newLocation) {locationMap.put(carCode, newLocation);}/*** 获取车辆位置** @param carCode 车辆斌吗* @return*/public Location getLocation(String carCode) {return locationMap.get(carCode);}
}

3.ThreadLocal

ThreadLocal 变量,线程局部变量.同一个ThreadLocal所包含的对象,在不同线程中有不同的副本。
	private static final ThreadLocal threadCount= new ThreadLocal();/*** ThreadLocal 变量,线程局部变量*/public void threadLocalParam(){Integer count = (Integer) threadCount.get();/*本次处理业务,统计*/count++;System.out.println(count);}

4.CAS原子类

CAS 机制,三个基本操作:内存地址V,旧的预期值A,要修改的新值B,只有当内存地址V所对应的值与旧的预期值A相等,才会将内存地址V对应的值更新为B。
    private AtomicInteger counter = new AtomicInteger(0);/*** cas 原子类,是个乐观锁,并发性能很高。通过compare and swap比较并置换的原子性设计,read 从jvm主存中读取旧值oldV,* 更新的时候,先比较oldV与主存中的v是否相等,相等就把newV更新替换v;如果不相等,继续while循环,从主存读取'新的'旧值oldV。** 底层是c++实现,保证三个步骤执行在硬件级别,是原子性,要么三个一起执行成功,又不继续循环直到成功。*/public void atomicAdd(){//比如接口访问总次数统计System.out.println(counter.incrementAndGet());}

二.有锁方式

1. 关键字synchronized

	//访问统计private int viewCount = 0;public synchronized void syncAdd(){addViewCount();}private void addViewCount(){viewCount++;}

2. 可重入锁ReentrantLock

	//悲观锁private ReentrantLock lock = new ReentrantLock();//访问统计private int viewCount = 0;private void addViewCount(){viewCount++;}/*** 通过执行方法前,加锁;执行完毕主动释放锁保证int++ 并发安全*/public void lockAdd(){lock.lock();try {addViewCount();} finally {lock.unlock();}}
http://www.yayakq.cn/news/345144/

相关文章:

  • 企业网站建设457216336html投票代码
  • 重庆手机网站制作费用郑州服装网站建设公司
  • 顺德建网站的公司网址缩短在线生成器永久
  • 网站备案登录科技公司官网
  • 辽宁pc网站建设开发去掉域名后的wordpress
  • 专业做网文的网站好建筑网片的用途有哪些
  • 网站备案拍照wordpress font.googleapis
  • 河南省 门户网站建设要求wordpress系统设置
  • 网页升级访问站一级建造师报名官网入口
  • 重庆的电子商务网站seo指的是搜索引擎
  • 网站备案麻烦什么是电商平台怎么加入电商平台
  • wordpress公司展示网站模板2017优秀网站设计
  • 网站建设费 账务处理小说网站自动采集
  • 关于手表网站建设策划书一对一软件
  • 建设部城市管理监督局网站wordpress set option
  • 免费网站建设无广告挖金矿游戏网站建设
  • 网站建设合同书相关附件宝安沙井邮政编码
  • 做网站游戏的网站有哪些建设商城网站的
  • 网站建设排名的公司哪家好凡科快图是免费的吗
  • 两学一做注册网站一级a做爰免费网站
  • 做网站的软件 简单易学网址模版
  • 水果门户网站建设无锡百姓网免费发布信息网
  • 怎么用asp.net做网站中国建设银行金华分行网站
  • 网站设计这个专业怎么样建设部网站注册师
  • 怎样给网站做后台七星彩网投网站建设
  • php做网站如何做一个网页项目
  • 建设网站的意义怎么查看网站有没有备案
  • 清远做网站东莞定制建站网站推广公司
  • 太原论坛网站开发公司深圳做兼职的网站
  • led网站免费模板中国人做外贸网站都卖什么手续