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

网站优化目录所有浏览器大全图片

网站优化目录,所有浏览器大全图片,百度搜索引擎优化方案,国家企业信用平台官网文章目录 学习链接CountDownLatchCountDownLatch类的作用类的主要方法介绍图解await和countDown方法两个典型用法注意点总结示例CountDownLatchDemo1CountDownLatchDemo2CountDownLatchDemo1And2 CyclicBarrierCyclicBarrier循环栅栏CyclicBarrier和CountDownLatch的区别示例Cy… 文章目录 学习链接CountDownLatchCountDownLatch类的作用类的主要方法介绍图解await和countDown方法两个典型用法注意点总结示例CountDownLatchDemo1CountDownLatchDemo2CountDownLatchDemo1And2 CyclicBarrierCyclicBarrier循环栅栏CyclicBarrier和CountDownLatch的区别示例CyclicBarrierDemo SemaphoreSemaphore信号量Semaphore应用实例信号量的使用流程信号量主要方法介绍信号量的特殊用法注意点示例SemaphoreDemo ConditionCondition的作用signalAll和signal的区别Condition注意点示例Condition1Condition2 学习链接 Java并发编程第9讲——CountDownLatch、CyclicBarrier和Semaphore万字详解 CountDownLatch CountDownLatch类的作用 类的主要方法介绍 图解await和countDown方法 两个典型用法 注意点 总结 示例 CountDownLatchDemo1 /*** 描述工厂中质检5个工人检查所有人都认为通过才通过*/ public class CountDownLatchDemo1 {public static void main(String[] args) throws InterruptedException {CountDownLatch latch new CountDownLatch(5);ExecutorService service Executors.newFixedThreadPool(5);for (int i 0; i 5; i) {final int no i 1;Runnable runnable new Runnable() {Overridepublic void run() {try {Thread.sleep((long) (Math.random() * 10000));System.out.println(No. no 完成了检查。);} catch (InterruptedException e) {e.printStackTrace();} finally {latch.countDown();}}};service.submit(runnable);}System.out.println(等待5个人检查完.....);latch.await(); // 这里也可以设置超时等待时间, 如: latch.await(5, TimeUnit.SECONDS);System.out.println(所有人都完成了工作进入下一个环节。);} } CountDownLatchDemo2 /*** 描述模拟100米跑步5名选手都准备好了只等裁判员一声令下所有人同时开始跑步。*/ public class CountDownLatchDemo2 {public static void main(String[] args) throws InterruptedException {CountDownLatch begin new CountDownLatch(1);ExecutorService service Executors.newFixedThreadPool(5);for (int i 0; i 5; i) {final int no i 1;Runnable runnable new Runnable() {Overridepublic void run() {System.out.println(No. no 准备完毕等待发令枪);try {begin.await();System.out.println(No. no 开始跑步了);} catch (InterruptedException e) {e.printStackTrace();}}};service.submit(runnable);}//裁判员检查发令枪...Thread.sleep(5000);System.out.println(发令枪响比赛开始);begin.countDown();} }CountDownLatchDemo1And2 /*** 描述模拟100米跑步5名选手都准备好了只等裁判员一声令下所有人同时开始跑步。当所有人都到终点后比赛结束。*/ public class CountDownLatchDemo1And2 {public static void main(String[] args) throws InterruptedException {CountDownLatch begin new CountDownLatch(1);CountDownLatch end new CountDownLatch(5);ExecutorService service Executors.newFixedThreadPool(5);for (int i 0; i 5; i) {final int no i 1;Runnable runnable new Runnable() {Overridepublic void run() {System.out.println(No. no 准备完毕等待发令枪);try {begin.await();System.out.println(No. no 开始跑步了);Thread.sleep((long) (Math.random() * 10000));System.out.println(No. no 跑到终点了);} catch (InterruptedException e) {e.printStackTrace();} finally {end.countDown();}}};service.submit(runnable);}//裁判员检查发令枪...Thread.sleep(5000);System.out.println(发令枪响比赛开始);begin.countDown();end.await();System.out.println(所有人到达终点比赛结束);} } CyclicBarrier CyclicBarrier循环栅栏 CyclicBarrier和CountDownLatch的区别 示例 CyclicBarrierDemo /*** 描述 演示CyclicBarrier*/ public class CyclicBarrierDemo {public static void main(String[] args) {// 5个线程都调用await时才执行Runnable然后5个线程接着执行CyclicBarrier cyclicBarrier new CyclicBarrier(5, new Runnable() {Overridepublic void run() {System.out.println(所有人都到场了 大家统一出发);}});// 这里循环10次目的是验证CyclicBarrier可重用for (int i 0; i 10; i) {new Thread(new Task(i, cyclicBarrier)).start();}}static class Task implements Runnable {private int id;private CyclicBarrier cyclicBarrier;public Task(int id, CyclicBarrier cyclicBarrier) {this.id id;this.cyclicBarrier cyclicBarrier;}Overridepublic void run() {System.out.println(线程 id 现在前往集合地点);try {Thread.sleep((long) (Math.random() * 10000));System.out.println(线程 id 到了集合地点开始等待其他人到达);cyclicBarrier.await();System.out.println(线程 id 出发了);} catch (InterruptedException e) {e.printStackTrace();} catch (BrokenBarrierException e) {e.printStackTrace();}}} } Semaphore Semaphore信号量 Semaphore应用实例 信号量的使用流程 信号量主要方法介绍 信号量的特殊用法 注意点 示例 SemaphoreDemo /*** 描述 演示Semaphore用法*/ public class SemaphoreDemo {static Semaphore semaphore new Semaphore(3, true);public static void main(String[] args) {ExecutorService service Executors.newFixedThreadPool(50);for (int i 0; i 100; i) {service.submit(new Task());}service.shutdown();}static class Task implements Runnable {Overridepublic void run() {try {semaphore.acquire(1);} catch (InterruptedException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName() 拿到了许可证);try {Thread.sleep(2000);} catch (InterruptedException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName() 释放了许可证);semaphore.release(1);}} }Condition Condition的作用 signalAll和signal的区别 Condition注意点 示例 Condition1 /*** 描述演示Condition的基本用法*/ public class ConditionDemo1 {private ReentrantLock lock new ReentrantLock();private Condition condition lock.newCondition();void method1() throws InterruptedException {lock.lock();try{System.out.println(条件不满足开始await);condition.await(); // 可设置超时时间进入条件等待: condition.await(1, TimeUnit.SECONDS);System.out.println(条件满足了开始执行后续的任务);}finally {lock.unlock();}}void method2() {lock.lock();try{System.out.println(准备工作完成唤醒其他的线程);condition.signal();}finally {lock.unlock();}}public static void main(String[] args) throws InterruptedException {ConditionDemo1 conditionDemo1 new ConditionDemo1();new Thread(new Runnable() {Overridepublic void run() {try {Thread.sleep(1000);conditionDemo1.method2();} catch (InterruptedException e) {e.printStackTrace();}}}).start();conditionDemo1.method1();} }Condition2 /*** 描述 演示用Condition实现生产者消费者模式*/ public class ConditionDemo2 {private int queueSize 10;private PriorityQueueInteger queue new PriorityQueueInteger(queueSize);private Lock lock new ReentrantLock();// 当队列不满足 不满的条件时生产者进入等待// 当队列不满时唤醒在此条件中等待的线程private Condition notFull lock.newCondition();// 当队列不满足 不空的条件时消费者进入等待// 当队列不空时唤醒在此条件中等待的线程private Condition notEmpty lock.newCondition();public static void main(String[] args) {ConditionDemo2 conditionDemo2 new ConditionDemo2();Producer producer conditionDemo2.new Producer();Consumer consumer conditionDemo2.new Consumer();producer.start();consumer.start();}class Consumer extends Thread {Overridepublic void run() {consume();}private void consume() {while (true) {lock.lock();try {// 使用while, 防止了虚假唤醒while (queue.size() 0) {System.out.println(队列空等待数据);try {// 当队列为空时进入等待// 当队列不为空时被唤醒notEmpty.await(); // 进入条件队列中等待并释放锁此处被唤醒时仍然需要获取到锁才能往下运行} catch (InterruptedException e) {e.printStackTrace();}}// 走到这里说明队列肯定不为空了// 因为先持有了锁, 所以保证了操作的原子性。其它此时尝试从该队列中获取数据的线程将进入锁等待环节queue.poll();// 因为拿到了锁, 并且从队列中获取了数据, 队列此时肯定不为满了, 所以可以唤醒生产者线程去生产notFull.signalAll();System.out.println(从队列里取走了一个数据队列剩余 queue.size() 个元素);} finally {lock.unlock();}}}}class Producer extends Thread {Overridepublic void run() {produce();}private void produce() {while (true) {lock.lock();try {// 使用while, 防止了虚假唤醒while (queue.size() queueSize) {System.out.println(队列满等待有空余);try {// 当队列为满时进入等待// 当队列为不满时被唤醒notFull.await(); // 进入条件队列中等待并释放锁此处被唤醒时仍然需要获取到锁才能往下运行} catch (InterruptedException e) {e.printStackTrace();}}// 走到这里说明队列肯定不为满了// 因为先持有了锁, 所以保证了操作的原子性。其它此时尝试往该队列中添加数据的线程将进入锁等待环节queue.offer(1);// 因为拿到了锁, 并且往该队列中添加了数据, 队列此时肯定不为空了, 所以可以唤醒消费者者线程去消费notEmpty.signalAll();System.out.println(向队列插入了一个元素队列剩余空间 (queueSize - queue.size()));} finally {lock.unlock();}}}}}
http://www.dnsts.com.cn/news/209915.html

相关文章:

  • 做烘培的网站网站注册流程和费用
  • 沈阳免费做网站搜索引擎seo优化
  • 成都水高新区建设局官方网站在大学做网站
  • 军事信息化建设网站莆田网站建设平台
  • 电子商务网站开发参考文献深圳龙华医院
  • 蓝色大气网站源码温江做网站
  • 网站加载动画效果loading网站源码平台
  • 北京做网站好的公司北京到广州航班时刻表
  • 手机网站域名注册昆明网站优化排名推广
  • 针对网站开发软件 代替手动移动端响应式网站怎么做
  • 国外wordpress主题站云南安宁做网站的公司
  • 杭州 城西 做网站2022年域名申请时间
  • 办公家具网站模版工业设计本科生作品集
  • 中小企业建网站注意成都公司注册价格
  • 网站制作咨询电话wordpress企业外贸主题
  • 公司网站注册要多少钱wordpress做电影网站
  • 门户网站后台建设模块应持续抓好二级网站的建设工作
  • 免费建站优化怎么用ps做京东网站模板
  • 自己做的网页怎么连接到网站官方网站模板
  • 网站开发计划怎么写企业网络规划与设计
  • 做网站素材平面设计培训怎么样
  • 企业网站的网络营销小辉seo
  • 昆明做网站ynlongtou王烨在地府是什么身份
  • title:(网站建设)深圳市住房和建设局网站怎么打不开了
  • h5网站设计欣赏怎么制作app软件需要多少钱
  • 管理类手机网站网站视觉设计原则
  • 租网站服务器游戏网站开发协议
  • 国内出色的网站建设公司wordpress admin head
  • delphi网站开发教程网站建设专家哪家好
  • 河南新闻头条最新事件魔贝课凡seo课程好吗