多线程 - CountDownLatch 和 Semaphore

冷不防 2023-09-26 19:24 259阅读 0赞

介绍:

CountDownLatch 和 Semaphore 都是 Java 多线程编程中的同步工具,用于控制线程的执行顺序和对共享资源的访问控制。

CountDownLatch 是一个计数器,允许一个或多个线程等待其他线程完成操作后再执行。在 CountDownLatch 初始化时设置一个计数器,每个线程完成任务后将计数器减 1,当计数器变为 0 时,等待的线程将被唤醒。

Semaphore 是一个信号量,用于控制同时访问共享资源的线程数量。Semaphore 在初始化时设置一个许可证数量,表示可以同时访问资源的线程数量,每个线程访问资源前需要获取一个许可证,访问结束后释放该许可证。

区别:

CountDownLatch 和 Semaphore 在功能上有一些区别,CountDownLatch 用于等待其他线程完成某个操作,而 Semaphore 则用于限制同时访问共享资源的线程数量。

在实现上,CountDownLatch 只能使用一次,即计数器减为 0 后不能再次使用,而 Semaphore 可以重复使用,即许可证数量可以被释放和重新获取。

另外,CountDownLatch 计数器的初始值是固定的,而 Semaphore 的许可证数量可以动态调整。

CountDownLatch

  1. import java.util.concurrent.CountDownLatch;
  2. /**
  3. * 在这个示例中,我们创建了一个 CountDownLatch 对象,并将其初始化为 5。
  4. * 然后,我们创建了 5 个线程,并在每个线程中调用 countDown 方法,以表示该线程已完成其任务。
  5. * 最后,我们调用 await 方法来等待所有线程完成任务,并输出 "All threads completed"。
  6. *
  7. * countDownLatch.countDown():表示该线程已完成其任务
  8. * countDownLatch.await() :等待所有线程完成任务
  9. */
  10. public class CountDownLatchExample {
  11. public static void main(String[] args) throws InterruptedException {
  12. int numOfThreads = 5;
  13. CountDownLatch countDownLatch = new CountDownLatch(numOfThreads);
  14. for (int i = 0; i < numOfThreads; i++) {
  15. new Thread(() -> {
  16. System.out.println("Thread " + Thread.currentThread().getId() + " started");
  17. countDownLatch.countDown();
  18. System.out.println("Thread " + Thread.currentThread().getId() + " completed");
  19. }).start();
  20. }
  21. countDownLatch.await();
  22. System.out.println("All threads completed");
  23. }
  24. }

Semaphore

  1. import java.util.concurrent.Semaphore;
  2. /**
  3. * 在这个示例中,我们创建了一个 Semaphore 对象,并将其初始化为 3。然后,我们创建了 5 个线程,
  4. * 并在每个线程中调用 acquire 方法来获取许可证。如果许可证数量已达到 3 个,则线程将被阻塞直到有一个许可证可用.
  5. * 当线程完成其任务后,它将调用 release 方法来释放许可证,并使其可用于其他线程。
  6. *
  7. * 在这个示例中,我们使用 Thread.sleep 来模拟每个线程完成其任务所需的时间。
  8. *
  9. * semaphore.acquire():获取许可证
  10. * semaphore.release():释放许可证
  11. */
  12. public class SemaphoreExample {
  13. public static void main(String[] args) {
  14. int numOfPermits = 3;
  15. Semaphore semaphore = new Semaphore(numOfPermits);
  16. for (int i = 0; i < 5; i++) {
  17. new Thread(() -> {
  18. try {
  19. semaphore.acquire();
  20. System.out.println("Thread " + Thread.currentThread().getId() + " acquired a permit");
  21. Thread.sleep(1000);
  22. semaphore.release();
  23. System.out.println("Thread " + Thread.currentThread().getId() + " released a permit");
  24. } catch (InterruptedException e) {
  25. e.printStackTrace();
  26. }
  27. }).start();
  28. }
  29. }
  30. }

发表评论

表情:
评论列表 (有 0 条评论,259人围观)

还没有评论,来说两句吧...

相关阅读