偶然发现Semaphore这个有用的工具,记录一下。
Example
需求背景: 一个厕所只有3个坑位,但是有10个人来上厕所,那怎么办?假设10的人的编号分别为1-10,并且1号先到厕所,10号最后到厕所。那么1-3号来的时候必然有可用坑位,顺利如厕,4号来的时候需要看看前面3人是否有人出来了,如果有人出来,进去,否则等待。同样的道理,4-10号也需要等待正在上厕所的人出来后才能进去,并且谁先进去这得看等待的人是否有素质,是否能遵守先来先上的规则。
import java.util.Random;
import urrent.Semaphore;/*** 如厕管理系统*/
class Ruce implements Runnable {private String userName;private Semaphore pots;public Ruce(String userName, Semaphore pots) {this.userName = userName;this.pots = pots;}@Overridepublic void run() {try {// 查询剩下的资源(剩下的茅坑)int availablePermits = pots.availablePermits();if (availablePermits > 0) {System.out.println(userName + "有茅坑...");} else {System.out.println(userName + "没有茅坑了...");}//申请茅坑 如果资源达到规定的次数,就等待pots.acquire();System.out.println(userName + "我开始上厕所了..");Thread.sleep(new Random().nextInt(3000)); // 模拟上厕所时间。System.out.println(userName + "厕所上完了...爽啊!");lease();} catch (Exception e) {e.printStackTrace();}}
}
import urrent.Semaphore;public class TestSemaphore {public static void main(String[] args) {// 一个厕所只有3个坑位,但是有10个人来上厕所,那怎么办?假设10的人的编号分别为1-10,并且1号先到厕所,10号最后到厕所。那么1-3号来的时候必然有可用坑位,顺利如厕,4号来的时候需要看看前面3人是否有人出来了,如果有人出来,进去,否则等待。同样的道理,4-10号也需要等待正在上厕所的人出来后才能进去,并且谁先进去这得看等待的人是否有素质,是否能遵守先来先上的规则。Semaphore semaphore = new Semaphore(3);for (int i = 1; i <= 10; i++) {Ruce parent = new Ruce("第" + i + "个人,", semaphore);new Thread(parent).start();}}
}
怎么样,Semaphore这个小工具是不是很有用~
本文发布于:2024-02-01 00:31:42,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170671870432517.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |