java并发:线程同步机制之Semaphore
2021/7/10 9:35:45
本文主要是介绍java并发:线程同步机制之Semaphore,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
一、初识Semaphore
小结:
A、可以将信号量可视化为一个计数器,它可以递增或递减。
B、从概念上讲,信号量维护了一个许可集合,Semaphore对可用的许可进行计数。
C、当计数器的值为0时,它能够使线程等待。
二、示例
The three steps you must follow when you use a semaphore to implement a critical section and protect the access to a shared resource:
- First, you acquire the semaphore, with the acquire() method.
- Then, you do the necessary operations with the shared resource.
- Finally, release the semaphore with the release() method.
场景:
假设一个服务器资源有限,任意某一时刻只允许3个人同时访问,这时一共来了10个人
package com.test; import java.util.concurrent.Semaphore; public class SemaphoreDemo{ public static void main(String args[]) throws Exception{ final Semaphore semaphore = new Semaphore(3);//一次只允许3个人进行访问 for(int i=0;i<10;i++) { final int no = i; Runnable thread = new Runnable() { public void run (){ try { System.out.println("用户"+no+"连接上了:"); Thread.sleep(300L); semaphore.acquire();//获取执行的许可 System.out.println("用户"+no+"开始访问后台程序..."); Thread.sleep(1000L);//模仿用户访问服务过程 semaphore.release();//释放,允许下一个线程访问后台 System.out.println("用户"+no+"访问结束。"); } catch (InterruptedException e) { e.printStackTrace(); } } }; new Thread(thread).start(); } System.out.println("Main thread end!"); } }
上述代码运行结果如下:
用户1连接上了: 用户3连接上了: 用户4连接上了: 用户2连接上了: 用户0连接上了: 用户5连接上了: 用户7连接上了: Main thread end! 用户6连接上了: 用户8连接上了: 用户9连接上了: 用户3开始访问后台程序... 用户4开始访问后台程序... 用户2开始访问后台程序... 用户4访问结束。 用户3访问结束。 用户7开始访问后台程序... 用户0开始访问后台程序... 用户8开始访问后台程序... 用户2访问结束。 用户5开始访问后台程序... 用户0访问结束。 用户7访问结束。 用户1开始访问后台程序... 用户8访问结束。 用户6开始访问后台程序... 用户1访问结束。 用户9开始访问后台程序... 用户5访问结束。 用户6访问结束。 用户9访问结束。
从结果上可以看出来,10个人同时进来,但是只能同时3个人访问资源,释放一个允许进来一个
Note:
When a thread has finished the use of the shared resource, it must release the semaphore so that the other threads can access the shared resource.
That operation increases the internal counter of the semaphore.
三、详解Semaphore
四、参考资料
(1)https://howtodoinjava.com/java/multi-threading/binary-semaphore-tutorial-and-example/
(2)https://howtodoinjava.com/java/multi-threading/control-concurrent-access-to-multiple-copies-of-a-resource-using-semaphore/
这篇关于java并发:线程同步机制之Semaphore的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-11有哪些好用的家政团队管理工具?
- 2025-01-11营销人必看的GTM五个指标
- 2025-01-11办公软件在直播电商前期筹划中的应用与推荐
- 2025-01-11提升组织效率:上级管理者如何优化跨部门任务分配
- 2025-01-11酒店精细化运营背后的协同工具支持
- 2025-01-11跨境电商选品全攻略:工具使用、市场数据与选品策略
- 2025-01-11数据驱动酒店管理:在线工具的核心价值解析
- 2025-01-11cursor试用出现:Too many free trial accounts used on this machine 的解决方法
- 2025-01-11百万架构师第十四课:源码分析:Spring 源码分析:深入分析IOC那些鲜为人知的细节|JavaGuide
- 2025-01-11不得不了解的高效AI办公工具API