最新文章列表

java线程间等待并传递数据

线程间传递数据,有多种方式可以做到,下面列举三种出来。 假设有A线程等待并获取B线程执行的结果。 1、通过wait/notify方式; A与B共同持有一个锁对象lock,A先获取lock的锁并在其上调用wait方法; B运行,计算出结果后,将结果值保存到一个A可以访问的volatile变量中,并调用lock的notify 2、通过SynchronousQueue方式; A与B共同持有一个S ...
huihuilou 评论(0) 有3555人浏览 2013-08-31 18:24

jdk1.5的CountDownLatch同步工具

package cn.com.songjy.test.socket.thread; import java.util.concurrent.CountDownLatch; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import org.apache.commo ...
宋建勇 评论(0) 有810人浏览 2013-08-27 13:37

Java并发编程: 使用CountDownLatch协调子线程

本文将介绍CountDownLatch工具类,并采用这个工具类给出一个实例。 1. CountDownLatch工具类介绍 CountDownLatch是一个同步工具类,它允许一个或多个线程处于等待状态直到在其它线程中运行的一组操作完成为止。CountDownLatch用一个给定的计数来实现初始化。Await方法会一直处于阻塞状态,直到countDown方法调用而使当前计数达到零。当计数为零之后 ...
MouseLearnJava 评论(8) 有6263人浏览 2013-07-30 11:19

Java线程同步器

1.CyclicBarrier(屏障)    CyclicBarrier类是通过设置屏障点来管理同步的,当所有参与的线程都到达指定屏障的时候,那么参与的所有线程就会全部    积蓄运行,具体测试代码如下:   public class CyclicBarrierTest { // 定义一个循环屏障 private CyclicBarrier cyclicBarrier; // ...
csyqbtlsz 评论(0) 有675人浏览 2013-05-14 18:18

53、java.util.concurrent.其它同步工具类

一、java.util.concurrent.Semaphore /** * Semaphore * 一个计数信号量。 * 从概念上讲,信号量维护了一个许可集。如有必要,在许可可用前会阻塞每一个 acquire(),然后再获取该许可。 * 每个 release() 添加一个许可,从而可能释放一个正在阻塞的获取者。但是,不使用实际的许可对象,Semaphore 只对可用许可的号码 ...
豆豆咖啡 评论(0) 有774人浏览 2013-04-18 11:07

CountDownLatch 与 CyclicBarrier

  CountDownLath :用于多任务查询,适用于等待所有任务都返回或超时场景。如下:     class CountDownLatchJob implements Runnable{ private CountDownLatch latch; private String name; private int waitTime; public Coun ...
白浪滔天 评论(0) 有1070人浏览 2013-01-30 22:27

java同步例子之闭锁(CountDownLatch)

在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待,在某些场景下同CyclicBarrier类似。 package concurrent; import java.util.concurrent.CountDownLatch; /** * 闭锁,要关注await,countDown的异常, * @author user * */ public cl ...
buzhucele 评论(0) 有2341人浏览 2012-11-02 16:18

用闭锁测试HashMap的并发写入问题

今天无意中看到以前写的代码,是一个单例的工厂模式实现,代码片段如下:   private static Map daoMap = new HashMap(); public static Dao createDao(String className) ...
378629846 评论(7) 有3662人浏览 2012-08-27 19:39

尽量把CyclicBarrier和CountDownLatch的区别说通俗点

先说两点都知道的: 1.CountDownLatch减计数,CyclicBarrier加计数。 2.CountDownLatch是一次性的,CyclicBarrier可以重用。 然后我们用被大家说烂了的跑步的例子继续说事儿: 1. 有五个人,一个裁判。这五个人同时跑,裁判开始计时,五个人都到终点了,裁判喊停,然后统计这五个人从开始跑到最后一个撞线用了多长时间。 import java.ut ...
aaron-han 评论(0) 有9508人浏览 2012-07-13 15:55

CountDownLatch

CountDownLatch如其所写,是一个倒计数的锁存器,当计数减至0时触发特定的事件。利用这种特性,可以让主线程等待子线程的结束。 private static final int THREADS = 100; /** 预设计数器 */ final CountDownLatch ct = new CountDownLatch(THREADS); for (int i = 0; i < ...
wingware 评论(0) 有982人浏览 2012-05-28 11:56

java CountDownLatch 实例

一个线程等待   CountDownLatch使用其await()等待其他线程完成(使用减值为0来判断是否完成)。 是一个线程等待多个线程(1-N)的锁工具。   以下为实例代码:   package com.common; import java.util.concurrent.CountDownLatch; import java.util.concurrent.Exec ...
blackproof 评论(0) 有1669人浏览 2012-05-13 10:37

【java并发】juc高级锁机制探讨

    最近在看一些juc相关的设计和源码,接上文 :【java并发】基于JUC CAS原理,自己实现简单独占锁 本文探讨一下juc里面提供的一些高级锁机 ...
singleant 评论(1) 有8690人浏览 2012-02-23 00:52

Java中的多线程竞争与CountDownLatch的应用

线程间的竞争叫做Racing,正如这篇文章的图片一样,不同的线程好比在高速赛道上行驶的F1方程式赛车,当赛车在各自的赛道上互不影响各自行驶时,可以相安无事。但这是一场比赛,既然是比赛,必然有并线、超车的行为,此时两辆赛车很可能会挤到赛道中公共的部分,如果此时两车速度相差不多,而且距离差距不大,就极有可能发生可怕的事故。 在计算机世界里,不同的线程运行的程序就好比不同赛道上的赛车。如果各个线程相 ...
阿男bluedash 评论(1) 有2407人浏览 2011-11-25 01:33

Java并发编程(二) CountDownLatch

接上一回,如果4个工人在装配车轮时,工作间中没有车轮可装配,工人必须等到车轮运送到工作间合适的位置后才可以进行装配车轮的工作。所以,在Worker类中加入一把新的CountDownLatch-----tyreReadyLatch, 让这把锁告诉Worker线程,在轮胎到来之前,必须处于等待状态,假如不等待的话,这个Worker线程会跑出错误,导致的结果是这辆车装配轮胎整个任务失败。所以必须调用 ...
Mojarra 评论(2) 有1902人浏览 2011-11-15 16:22

Java并发编程(一) CountDownLatch

介绍 CountDownLatch是JDK5引入的一个新的线程辅助类,用于帮助开发人员”比较精确"的控制线程状态。CountDownLatch这个类内置了一个锁计数器,这个计数器由新建这个类的实例时指定,每调用countDown()方法一次,计数器的数字减一,当计数器为零时,所有的等待线程被释放并执行,否则这些线程是处于等待状态。   这个类在两种典型的场合下可以用得到。   第 ...
Mojarra 评论(0) 有2593人浏览 2011-11-15 12:13

JDK-CountDownLatch

AliKevin 写道CountDownLatch位于java.util.concurrent包中,它是一个通用同步工具,它有很多用途。我们利用将CountDownLatch要进行初始化,用1初始化的 CountDownLatch 用作一个简单的开/关锁存器或入口然后在通过调用 countDown() 的线程打开入口前,所有调用 await 的线程都一直在入口处等待。用 N 初始化的 CountDo ...
AliKevin2011 评论(0) 有1176人浏览 2011-10-21 13:56

CountDownLatch的使用

concurrent包里面的CountDownLatch其实可以把它看作一个计数器,只不过这个计数器的操作是原子操作,同时只能有一个线程去操作这个计数器,也就是同时只能有一个线程去减这个计数器里面的值。 CountDownLatch的一个非常典型的应用场景是:有一个任务想要往下执行,但必须要等到其他的任务执行完毕后才可以继续往下执行。假如我们这个想要继续往下执行的任务调用一个CountDownLat ...
latty 评论(6) 有5423人浏览 2011-10-10 19:00

CountDownLatch 的使用小例

CountDownLatch java.util.concurrent.CountDownLatch   它是一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待。 用给定 ...
z_kanhai 评论(0) 有827人浏览 2011-10-10 14:08

Java多线程--让主线程等待所有子线程执行完毕

   数据量很大百万条记录,因此考虑到要用多线程并发执行,在写的过程中又遇到问题,我想统计所有子进程执行完毕总共的耗时,在第一个子进程创建前记录当前时间用System.currentTimeMillis()在最后一个子进程结束后记录当前时间,两次一减得到的时间差即为总共的用时,代码如下     Java代码   long tStart = System.currentTimeMillis(); ...
iblike 评论(0) 有3360人浏览 2011-07-28 19:25

最近博客热门TAG

Java(141747) C(73651) C++(68608) SQL(64571) C#(59609) XML(59133) HTML(59043) JavaScript(54918) .net(54785) Web(54513) 工作(54116) Linux(50906) Oracle(49876) 应用服务器(43288) Spring(40812) 编程(39454) Windows(39381) JSP(37542) MySQL(37268) 数据结构(36423)

博客人气排行榜

    博客电子书下载排行

      >>浏览更多下载

      相关资讯

      相关讨论

      Global site tag (gtag.js) - Google Analytics