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

黄埔五屏网站建设凤岗镇网站仿做

黄埔五屏网站建设,凤岗镇网站仿做,典型的口碑营销案例,游戏推广赚佣金的平台1. CAS概述 CAS(Compare ans swap/set) 比较并交换#xff0c;实现并发的一种底层技术。它将预期的值和内存中的值比较#xff0c;如果相同#xff0c;就更新内存中的值。如果不匹配#xff0c;一直重试#xff08;自旋#xff09;。Java.util.concurrent.atomic包下的原…1. CAS概述 CAS(Compare ans swap/set) 比较并交换实现并发的一种底层技术。它将预期的值和内存中的值比较如果相同就更新内存中的值。如果不匹配一直重试自旋。Java.util.concurrent.atomic包下的原子类都使用了CAS算法 2. CAS原理 CAS具体的操作是将预期的值和内存中真实的值进行比较如果相同就更新值。如果不相同就重试自旋。 CAS是通过Unsafe的compareAndSwap方法实现的底层实现是CPU原子指令cmpxchg不会造成数据不一致的问题。 CAS依靠底层硬件实现的无锁原子算法。比synchronized重量级锁性能更好。 3. CAS与自旋锁 3.1 前置知识原子引用类AtomicReference 将自定义的类型变成原子类能够进行cas操作。 public static void main(String[] args){AtomicReferenceUser atomicReference new AtomicReference();User z3 new User(z3,22);User li4 new User(li4,28);atomicReference.set(z3);System.out.println(atomicReference.compareAndSet(z3, li4)\tatomicReference.get().toString());System.out.println(atomicReference.compareAndSet(z3, li4)\tatomicReference.get().toString());}3.2 CAS实现一个自旋锁A线程持有锁B线程自旋等待直到A释放锁。 /*** 题目实现一个自旋锁,复习CAS思想* 自旋锁好处循环比较获取没有类似wait的阻塞。** 通过CAS操作完成自旋锁A线程先进来调用myLock方法自己持有锁5秒钟B随后进来后发现* 当前有线程持有锁所以只能通过自旋等待直到A释放锁后B随后抢到。*/ public class SpinLockDemo {AtomicReferenceThread atomicReference new AtomicReference();public void lock(){Thread thread Thread.currentThread();System.out.println(Thread.currentThread().getName()\t----come in 等待锁);while (!atomicReference.compareAndSet(null, thread)) {}System.out.println(Thread.currentThread().getName() \t 拿到锁);}public void unLock(){Thread thread Thread.currentThread();atomicReference.compareAndSet(thread,null);System.out.println(Thread.currentThread().getName()\t----task over,释放锁...);}public static void main(String[] args){SpinLockDemo spinLockDemo new SpinLockDemo();new Thread(() - {spinLockDemo.lock();//暂停几秒钟线程try { TimeUnit.SECONDS.sleep(5); } catch (InterruptedException e) { e.printStackTrace(); }spinLockDemo.unLock();},A).start();//暂停500毫秒,线程A先于B启动try { TimeUnit.MILLISECONDS.sleep(500); } catch (InterruptedException e) { e.printStackTrace(); }new Thread(() - {spinLockDemo.lock();spinLockDemo.unLock();},B).start();} }核心思想 加锁开始的时候内存中的值为NULL一旦有线程进入预期值为NULL,和真实值匹配将内存设置为当前线程值。(此时其他线程进来后预期值NULL但是真实值已经被修改所以会自旋这为加锁)解锁 释放锁之后重新设置内存的值为NULL让其他线程能够进入从而修改 运行结果 CAS和synchronized比较 CAS线程不会阻塞线程一直自旋。 Synchronized会阻塞会进行线程的上下文切换非常耗费资源。 CAS缺点 循环时间长开销大 CAS如果预测值和真实值不一样将一直自旋。导致循环CPU开销大。 ABA问题 ABA问题顾名思义就是将线程1在进行CAS操作的时候另一个线程2已经将A修改为B又快速修改回A导致一个线程并未发现中间修改过仍能正常进行CAS比较和修改。 ABA问题解决方案 原子时间戳引用给每次修改都加上一个时间戳(版本号)CAS操作的时候不仅要比较预测值和真实值还要比较预测版本号和真实版本号。 new AtomicStampedReference().compareAndSet(V expectedReference,V newReference,int expectedStamp,int newStamp)CAS注意事项 CAS只能保证原子性不能保证变量的可见性。要配合volatile使用保证共享变量的可见性。 CAS适用于并发量不高多核CPU的情况。并发量增高CAS自旋会导致消耗CPU资源。这时候用LongAdder
http://www.hkea.cn/news/14519358/

相关文章:

  • 邢台地区网站建设口碑好个人物流网站建设方案
  • 163企业邮箱app下载杭州抖音seo
  • 网站空间ip地址查询房地产型网站建设
  • 网站建设 嘉定济南市城市建设规划局官方网站
  • 广州 网站的设计公司网站建设 主机选择
  • 网站开发和运行 法律wap织梦手机网站
  • 京东网站开发费用英文网站cms
  • 网站风格设计的选择打开网站搜索
  • 青海省建设厅职业注册官方网站杭州网络科技设计中心
  • 晋中工商局网站开发区分局金华手机模板建站
  • 企业网站seo外包公司名字大全2022
  • 做网站第一步做什么微信小程序开发费用
  • 网站必须做电子认证吗海报制作软件免费版
  • 淄博公益网站建设如何把网站做成app
  • 家具网站建设公司建设网站需要哪些软硬件条件
  • 有没有发布需求的网站上海发布官网首页
  • 温州建设网站制作网络技术题库
  • 网站自定义功能实现网络基础架构
  • 古镇网站建设公司什么网站做外链优化好
  • 菏泽网站建设电话英文网站seo推广
  • 网站用户黏度wordpress登陆页面模板下载
  • 企业+网站+wordpress做特卖的网站
  • 庆阳网站建设推广成都旅游景点有哪些
  • 织梦制作手机网站模板阿里云虚拟主机装WordPress
  • 网站建设好国际外贸交易平台有哪些
  • 网站开发怎样建立后台数据最吸引人的营销广告词
  • 网站制作流程分为哪三步网站描述作用
  • 个人做商机网站如何盈利安装字体到wordpress
  • 品牌型网站建设哪家网站首页的优化
  • 安徽合肥中国建设银行网站首页网站建设公司哪个好点