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

有赞官网seo搜索引擎优化薪酬

有赞官网,seo搜索引擎优化薪酬,公司内部管理系统软件,网站子页面设计#摘要 介绍基于AQS 实现的并发工具类 CountDownLatch Semaphore 源码分析 CountDownLatch 源码 CountDownLatch 是 Java 并发包 java.util.concurrent 中的一个同步工具类,它允许一个或多个线程等待其他线程完成操作。其核心原理是使用一个计数器,初始…

#摘要
介绍基于AQS 实现的并发工具类 CountDownLatch Semaphore 源码分析

CountDownLatch 源码

CountDownLatch 是 Java 并发包 java.util.concurrent 中的一个同步工具类,它允许一个或多个线程等待其他线程完成操作。其核心原理是使用一个计数器,初始值为需要等待的操作数量,当每个操作完成时,计数器的值减 1,当计数器的值变为 0 时,等待的线程将被唤醒继续执行。

1 类接口

允许一个或多个线程等待,直到其他线程中正在执行的一组操作完成。
会使用给定的计数进行初始化。await 方法会阻塞调用线程,直到由于调用 countDown 方法使得当前计数达到零。此后,所有等待的线程都会被释放,并且任何后续对 await 的调用都会立即返回。
计数无法重置
使用场景:
1 启动信号 初始计数为 1 的 CountDownLatch 可作为一个简单的开关门闩或闸门:所有调用 await 的线程会在闸门处等待,直到有一个线程调用 countDown 打开闸门。
2 完成信号 初始计数为 N 的 CountDownLatch 可用于让一个线程等待,直到 N 个线程完成了某个操作,或者某个操作被执行了 N 次。
调用 countDown 扣减计数之后不会阻塞,

2 成员变量及其对应的数

	内部类  Sync 继承AQS 实现线程同步,state为当前计数,实现方法 tryAcquireShared(实际判断state是否为0 是,返回1 否则返回-1 ) 和 tryReleaseShared 用于控制state的更新java.util.concurrent.CountDownLatch#await() 阻塞直到被中断或者其他线程更新计数为0后唤醒当前线程实际上调用的是 AQS的  java.util.concurrent.locks.AbstractQueuedSynchronizer#acquireSharedInterruptibly AQS的方法会调用子类 Sync 的 tryAcquireShared 方法,在方法里判断当前state是否为0,如果不是0阻塞当前线程 java.util.concurrent.CountDownLatch#countDown 实际上调用的是 java.util.concurrent.locks.AbstractQueuedSynchronizer#releaseShared 会调用子类的  tryReleaseShared ,在该方法里面 CAS+死循环更新state,如果更新后state== 0 返回ture代表释放成功,AQS会唤醒同步队列上阻塞的线程、
阻塞和唤醒原理其实是使用了AQS 共享锁进行线程同步,执行countDown方法的线程是释放锁,执行await方法的线程是尝试获取锁,区别在于获取锁成功条件是当前state是否为0
之所以为共享锁,是因为共享锁获取锁后会执行 setHeadAndPropergate方法唤醒后续阻塞节点,使用排他锁,释放锁后唤醒第一个阻塞节点后,阻塞节点成功获取锁,后直接返回没有唤醒后继节点的操作

Semaphore 源码

1 类接口

内部类  Sync extends AbstractQueuedSynchronizer 复写 tryReleaseShared ,有子类分别实现公平和非公平逻辑、
NonfairSync tryAcquireSharednonfairTryAcquireShared  for死循环+CAS更新state 如果小于0 代表获取信号量失败,如果CAS成功返回剩余信号量。如果CAS失败,继续循环尝试获取直到成功
FairSync tryAcquireShared相比非公平锁,每次循环多了 hasQueuedPredecessors 判断同步队列head后的节点是否是当前线程如果不是 tryAcquireShared 方法返回-1代表获取信号量失败,当前 tryAcquireShared 方法返回-1 获取锁失败。否则CAS更新stat
该类的所有方法都代理给内部类  sync实现  
state被定义为信号量 ,该类支持公平和非公平逻辑

作用-> 接口暴露的方法源码

获取信号量方法(两个版本  -- 单独信号量操作和批量信号量操作)
acquire 中断响应 获取锁java.util.concurrent.locks.AbstractQueuedSynchronizer#acquireSharedInterruptibly
acquireUninterruptibly 不响应中断java.util.concurrent.locks.AbstractQueuedSynchronizer#acquireShared
tryAcquire() 子类的tryAcquire方法实现,忽略公平策略,直接尝试获取信号量忽略公平策略,直接尝试获取信号量,java.util.concurrent.Semaphore.Sync#nonfairTryAcquireShared
tryAcquire(long timeout, TimeUnit unit) 支持中断,超时响应java.util.concurrent.locks.AbstractQueuedSynchronizer#tryAcquireSharedNanos
获取信号量的线程阻塞在同步队列上,类型都是SHARED的,方便在 setHeadAndPropergate 中被唤醒释放信号量(两个版本  -- 单独信号量操作和批量信号量操作)
releasejava.util.concurrent.locks.AbstractQueuedSynchronizer#releaseShared  java.util.concurrent.Semaphore.Sync#tryReleaseShared 增加state返回true ,父类AQS会调用 doReleaseShared 唤醒同步队列的阻塞线程,阻塞线程唤醒后会获取锁,同时调用 setHeadAndPropergate 继续唤醒后续阻塞SHARED类型的阻塞节点
http://www.dtcms.com/wzjs/208517.html

相关文章:

  • 山门做网站百度推广代理商赚钱吗
  • 做任务得钱的网站手机百度2022年新版本下载
  • 新河镇网站制作网络软文名词解释
  • 宜春专业的企业网站建设公司网络营销推广技巧
  • 网站建设与管理维护 李建青网络电商推广方案
  • 淘宝客做自已的网站永久免费自助建站系统
  • 秦皇岛网站制作报价商品推广软文800字
  • 河南便宜网站建设价格洛阳网站seo
  • 顺德网站建设要多少钱app推广代理去哪里找
  • 网站建设方案功能软文营销经典案例
  • 石桥铺网站建设公司seo独立站
  • 武汉光谷企业网站建设百度seo效果
  • 做的好英文网站网站交易网
  • 广东粤建设计院网站推广软件排行榜前十名
  • 企业门户网站建设方案16888精品货源入口
  • 免费做微信请帖的网站seo推广培训
  • 汽车保险网站链接怎么做
  • 微信手机网站源码2345网址导航删除办法
  • 网站开发知识版权近几天的新闻摘抄
  • 网页设计网站制作收获宁夏百度公司
  • 非法网站开发企业模板建站
  • 许昌市建设投资有限公司 网站网络营销招聘
  • 建设网站公司 优帮云搜索引擎优化核心
  • 做公司网站的资料线上营销怎么做
  • 织梦猫html5高端网络服务机构网站模板西安网络科技有限公司
  • 从哪些方面进行网站建设湖南seo优化按天付费
  • 衡阳建设企业网站个人网站的制作
  • 建网站是不是免费的中国广告公司前十强
  • 做网站容易吧chrome官方下载
  • 做网站虚拟主机要多大站长工具seo综合查询广告