互联网面试题之CountDownLatch/CyclicBarrier/Semaphore用过吗

CountDownLatch

import java.util.concurrent.CountDownLatch;
import java.util.concurrent.TimeUnit;

/**
 * 秦灭六国,一统天下
 */
public class CountDownLatchDemo {

    public static final int NUM = 6;

    public static void main(String[] args) {
        // 设置计数器值
        CountDownLatch latch = new CountDownLatch(NUM);

        for(int i = 1; i <= NUM; i++) {
            new Thread(()-> {
                try {
                    TimeUnit.SECONDS.sleep(1);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }

                System.out.println( Thread.currentThread().getName() +  "员工下班");

                // 计数器值减1
                latch.countDown();

            }, String.valueOf(i)).start();
        }

        try {
            // 调用await方法,调用线程会被阻塞,其他线程调用countDown方法会将计数器减1
            // 当计数器的值变为0时,线程会被唤醒,继续执行。
            latch.await();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

        System.out.println("管理员锁门");
    }

}


CyclicBarrier

import java.util.concurrent.CyclicBarrier;
import java.util.concurrent.TimeUnit;

/**
 * 集齐七龙珠,召唤神龙
 * 人到齐了才开会
 *
 * CyclicBarrier 的字面意思是可循环(Cyclic)使用的屏障(Barrier)
 * 可以让一个线程到达一个屏障)(同步点)时被阻塞,直到最后一个线程到达屏障时,屏障才会开门。
 * 所有被屏障拦截的线程才会继续干活,线程进入屏障通过CyclicBarrier的await方法。
 */
public class CyclicBarrierDemo {

    public static void main(String[] args) {
        CyclicBarrier barrier = new CyclicBarrier(7, ()-> {
            System.out.println(Thread.currentThread().getName() + "召唤神龙");
        });

        for(int i = 1; i <= 7; i++) {
            final int tmp = i;
            new Thread(()-> {
                try {
                    TimeUnit.SECONDS.sleep(1);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                System.out.println(Thread.currentThread().getName() + "收集到第" + tmp + "颗龙珠");

                try {
                    // 等待
                    barrier.await();
                } catch (Exception e) {
                    e.printStackTrace();
                }

            }, String.valueOf(i)).start();
        }
    }
}

Semaphore

import java.util.concurrent.Semaphore;
import java.util.concurrent.TimeUnit;

/**
 * 信号量主要用于两个目的,一个是用于多个共享资源的互斥使用,另一个用于并发线程数控制。
 * 争车位
 */
public class SemaphoreDemo {

    public static void main(String[] args) {
        Semaphore semaphore = new Semaphore(3); // 模拟3个停车位

        for(int i = 0; i < 6; i++) {
            new Thread(()-> {
                try {
                    semaphore.acquire();
                    System.out.println(Thread.currentThread().getName() + "抢到车位");
                    TimeUnit.SECONDS.sleep(3);

                    System.out.println(Thread.currentThread().getName() + "停3秒后离开");

                } catch (InterruptedException e) {
                    e.printStackTrace();
                }finally {
                    semaphore.release();
                }
            }, String.valueOf(i)).start();
        }

    }

}


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章