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

互动科技网站建设关键词挖掘排名

互动科技网站建设,关键词挖掘排名,云南建设厅网站设计,青岛做网站推广这次整理了一些比较常用的线程工具类啦。 CountDownLatch#xff1a;在一组线程执行完后#xff0c;才能开始执行调用等待的线程。上片文章提到过junit的测试尽量不要测试线程#xff0c;如果硬是要可以使用CountDownLatch进行测试 CyclicBarrier#xff1a;在一组线程中…这次整理了一些比较常用的线程工具类啦。 CountDownLatch在一组线程执行完后才能开始执行调用等待的线程。上片文章提到过junit的测试尽量不要测试线程如果硬是要可以使用CountDownLatch进行测试 CyclicBarrier在一组线程中调用等待方法后只有这组所有线程都进入等待后会执行一个指定的线程在指定的线程执行完后这组等待的线程才能继续执行。 Semaphore可用于限流使用。 Exchanger当两组线程都执行到交换的方法时能将数据在这两个线程之间进行数据交换。 CountDownLatch 该类实现主要是由一个内部类Sync实现的Sync继承了AbstractQueuedSynchronizer(就是经常提到的AQS) 常用的方法有两个: 1.await():线程调用该方法进入带阻塞状态只有当调用countDown()并骤减到0的时候才能继续执行 2.countDown():线程骤减一个单位。 具体实现 public class CountDownLatchMain {static CountDownLatch latch new CountDownLatch(6);static class InitThread implements Runnable{public void run() {try {TimeUnit.MILLISECONDS.sleep(200L);} catch (InterruptedException e) {// TODO Auto-generated catch blocke.printStackTrace();}System.out.println(Thread name:Thread.currentThread().getName() init ...);latch.countDown();}}static class BusinessThread implements Runnable{public void run() {try {latch.await();} catch (InterruptedException e1) {e1.printStackTrace();}for(int i0;i3;i) {try {TimeUnit.MILLISECONDS.sleep(100L);} catch (InterruptedException e) {e.printStackTrace();}System.out.println(Thread name : Thread.currentThread().getName() work_ i);}}}public static void main(String[] args) throws InterruptedException {new Thread(new Runnable() {public void run() {latch.countDown();System.out.println(thread name Thread.currentThread().getName() 1st init ...);try {TimeUnit.MILLISECONDS.sleep(1000);} catch (InterruptedException e) {// TODO Auto-generated catch blocke.printStackTrace();}latch.countDown();System.out.println(thread name Thread.currentThread().getName() 2nd init ...);}},Thread-0).start();new Thread(new BusinessThread()).start();for(int i0;i4 ;i) {new Thread(new InitThread()).start();}latch.await();TimeUnit.MILLISECONDS.sleep(300);System.out.println(main end ...);} } 执行结果 thread name Thread-0 1st init ... Thread name:Thread-1 init ... Thread name:Thread-3 init ... Thread name:Thread-2 init ... Thread name:Thread-5 init ... Thread name:Thread-4 init ... Thread name : Thread-0 work_0 Thread name : Thread-0 work_1 Thread name : Thread-0 work_2 main end ... thread name Thread-0 2nd init ... CyclicBarrier 与CountDownLatch差不多都是等待线程执行完后才能继续执行不过这两个不同的地方就是CountDownLatch需要手动在逻辑代码中进行骤减减到临界点后阻塞的线程会继续执行而CountDownLatch是一组线程都进入到阻塞状态后然后执行指定线程执行完后那组阻塞的线程才能继续执行。 示例 public class CyclicBarrierMain {static CyclicBarrier barrier new CyclicBarrier(5,new Runnable() {public void run() {System.out.println(Thread name : Thread.currentThread().getName() barrier start...);try {TimeUnit.MILLISECONDS.sleep(100L);} catch (InterruptedException e) {// TODO Auto-generated catch blocke.printStackTrace();}System.out.println(Thread name : Thread.currentThread().getName() barrier thread ...);}});static class SubThread implements Runnable{public void run() {long sleep (long) (Math.random()*1000);System.out.println(thread name : Thread.currentThread().getName() init ...);try {TimeUnit.MILLISECONDS.sleep(sleep);} catch (InterruptedException e) {e.printStackTrace();}try {System.out.println(thread name : Thread.currentThread().getName() sleep time:sleep);barrier.await();} catch (InterruptedException e) {e.printStackTrace();} catch (BrokenBarrierException e) {e.printStackTrace();}System.out.println(thread name : Thread.currentThread().getName() end ....);}}public static void main(String[] args) {for(int i 0 ; i5;i) {new Thread(new SubThread()).start();}} } 执行结果 thread name : Thread-2 init ... thread name : Thread-4 init ... thread name : Thread-1 init ... thread name : Thread-0 init ... thread name : Thread-3 init ... thread name : Thread-2 sleep time:405 thread name : Thread-0 sleep time:488 thread name : Thread-1 sleep time:564 thread name : Thread-4 sleep time:777 thread name : Thread-3 sleep time:860 Thread name : Thread-3 barrier start... Thread name : Thread-3 barrier thread ... thread name : Thread-3 end .... thread name : Thread-2 end .... thread name : Thread-1 end .... thread name : Thread-0 end .... thread name : Thread-4 end .... Semaphore 主要用于需要做限制的场景比如限制连接池获取次数等等也有一个Sync内部类继承了AQS 常用方法 1、acquire():骤减一个单位也可调用带参的方法可指定减值当骤减到0的时候调用该方法会进入阻塞状态。 2、release():释放一个单位也会在初始化的数量进行增加。 3、availablePermits():得到可获取单位的数量。 4、getQueueLength()调用了acquire()方法并进入到阻塞状态的总数量。 具体用法 Semaphore semaphore new Semaphore(5); semaphore.acquire();//也可指定减少多个semaphore.acquire(2); //...第6个acquire()方法时,再次调用将进入等待直到在某个线程中执行了semaphore.release()方法才会继续执行后面的 //...Exchanger 主要用于两个线程之间的数据交换个人觉得这个用处不大既然看到了这个也就顺便整理了一下 使用示例 public class UseExcahnger {static ExchangerSetString exchanger new ExchangerSetString();static class ThreadOne extends Thread{Overridepublic void run() {SetString set new HashSetString();set.add(1);set.add(2);try {System.out.println(Thread.currentThread().getName() set: set);Thread.sleep(2000L);SetString exchange exchanger.exchange(set);System.out.println(Thread.currentThread().getName() exchange);} catch (InterruptedException e) {// TODO Auto-generated catch blocke.printStackTrace();}}}static class ThreadTwo extends Thread{Overridepublic void run() {SetString set new HashSetString();set.add(3);set.add(4);try {System.out.println(Thread.currentThread().getName() set: set);Thread.sleep(3000L);SetString exchange exchanger.exchange(set);System.out.println(Thread.currentThread().getName() exchange);} catch (InterruptedException e) {// TODO Auto-generated catch blocke.printStackTrace();}}}public static void main(String[] args) {new ThreadOne().start();new ThreadTwo().start();} } 执行结果为 Thread-0 set:[1, 2] Thread-1 set:[3, 4] Thread-1 [1, 2] Thread-0 [3, 4] Future/FutureTask 这个在之前的提到过与Callable一起使用用来做回调的个人觉得这个与之前的Fork/Join的分而治之有些相似都是异步同时执行完后将结果返回然后发现相似之后回去看了一下源代码 RecursiveAction和RecursiveTaskT 都分别继承了Future接口而FutureTask也继承了Future、Runnable所以FutureTask既能作为Callable带有返回结果也能作为Thread去执行它。 这里就介绍一下类中的一些方法示例的话可以翻看之前的文章 1、isDone()判断线程是否已结束。 2、boolean cancel(boolean mayInterruptIfRunning)参数为true是中断线程但是只会发送中断信号在程序中需要自行判断参数为false则不会中断返回值为true如果线程已结束或未开始则返回false。 3、isCancelled()判断线程是否关闭。 4、get()获取线程返回值。 好啦就先整理这些啦后面还有一些还在整理后期会继续分享的呀如果有问题烦请各路大佬指出
http://www.huolong8.cn/news/370977/

相关文章:

  • 做营销网站策划有什么前景建设网站投资多少
  • 凉山州规划和建设局网站山西有哪些做网站的公司
  • 可以自己做网站服务器不工信部备案号查询平台
  • 网站建设哪些好wordpress装主题失败
  • 二手网站建设登录网站怎么做
  • 为什么会显示危险网站移动网站设计方案
  • 购物网站页面设计图片wordpress 获取目录
  • 雅加达网站建设深圳网站建设费用是多少
  • 网站开发项目责任分配矩阵做交网站
  • 做最好最全的命理网站网站首页静态化代码
  • 一般网站维护要多久素材图
  • 网站广告调词软件如何设计营销 网站建设
  • 韩国风网站想做一个网站
  • 坐什么网站能用到html5旅游网站建设的可行性分析
  • 中文网站做google广告怎么样wordpress 线条不显示不出来
  • wordpress图片模板谁的网站模板利于优化
  • 深圳罗湖住房和建设局网站官网wordpress 置顶
  • 雅安网站开发关于中秋节网页设计实训报告
  • 企业网站的特征wordpress备份插件中文
  • 西安做网站南通公司外包公司的业务员
  • 建设网站需求分析wordpress文章自动截断
  • 百度 安徽省工程建设信息网站网站没收录的几大原因
  • 网站开发费属于无形资产做网站 做什么网站好
  • 网站线框图用什么做微信h5页面制作教程
  • 网站制作排行榜网站建设计什么费用
  • 电影网站空间配置网站开发毕业设计文档
  • 主题餐厅装修设计公司推广资源seo
  • 北京做网站ezhixi微信搜一搜seo优化
  • 高校网站建设工作总结pc端网站建设电话
  • 垂直网站 开源码怎么在拼多多卖东西