JAVA并发-线程协作

这段时间有点忙,技术博客更新的比较少,今天更新一下相关并发的常用线程协作的类吧。

ExecutorService

线程池,用于创造和复用线程,他有几种模式。

我举一个自定义线程池数量的例子如下

ExecutorService service = Executors.newFixedThreadPool(10);

 

CountDownLatch

主要用于通知等待线程什么时候能够开始运作。CountDownLatch 一般作为一个线程的内部变量并且通过构造函数传入

在线程内某时间结束后,调用countdown方法就会自动-1,当countdown计数器为0时,等待的线程就能继续运作了

ExecutorService service = Executors.newFixedThreadPool(10);
CountDownLatch end = new CountDownLatch(1);
service.submit(new ThreadA( end ))
end.await();

 

CyclicBarrier

一般用于设置线程的一个集合点,使用方式同CountDownLatch方法,区别在于这个类的await需要线程等待内部计数器完全结束至0后才会继续工作。

当线程池内的线程较少时,则可能容易死锁。此外次计数器在线程内部可重复使用

CyclicBarrier barrier = new CyclicBarrier(10);
barrier.await();

 

Semaphore

一般用于设置排队机制,多线程协作时某个方法最多进入X个线程。用法与之前的相似,设置一个最大限制值,但在完成操作后需要手动进行释放。

        Semaphore semaphore = new Semaphore(3);
        semaphore.acquire();
        semaphore.release();

 

Future

此方法用于异步处理一些复杂的操作,直接上例子吧 通过实现Callable接口的call方法进行包装,异步进行处理,然后通过future的get方法进行回调。

public class TestForThread {
    
    
    public int getRes(){
        try {
            Thread.sleep(10*1000);
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return 1000;
    }

    @Test
    public void fultrueTest() throws InterruptedException, ExecutionException {
        ExecutorService service = Executors.newFixedThreadPool(10);
        CountDownLatch end = new CountDownLatch(1);
        Semaphore semaphore = new Semaphore(3);
        Future<Integer> f = service.submit(new Callable<Integer>() {
            @Override
            public Integer call() throws Exception {
                // TODO Auto-generated method stub
                return new TestForThread().getRes();
            }
        });
        
        System.out.println("keep on ");
        System.out.println("get callable data");
        int a;
        try {
            a = f.get(15, TimeUnit.SECONDS);
            System.out.println(a);
        } catch (TimeoutException e) {
            // TODO Auto-generated catch block
            System.out.println("timeout");
        }
        System.out.println("end");
        end.await();
    }

}

 

 Exchanger 

这个用于线程之间的交换,比如一个线程读一个线程写,这个类我想了一下可能是为了节省一个Map的空间吧。不需要通过新建一个Map来存放临时数据。

具体事例不给啦,查API很简单的。(主要是我记不住 - -)

 

posted on 2015-02-04 11:09  sunfan  阅读(268)  评论(0编辑  收藏  举报