【说站】java使用Semaphore实现限流器
2024-11-04
41
java使用Semaphore实现限流器
概念
1、Semaphore可以看作是已经被广泛地翻译成信号量,从概念上讲,信号量保持了一组凭证,获得凭证的线程可以访问资源,使用完成后释放,我们可以使用信号量来限制访问特定资源的并发线程。
2、可以简单概括为:一个计数器,一个等待队列,三种方法。在信号量模型中,计数器和等待队列是透明的,只能通过信号量模型提供的三种方式访问,即互联网、acquire和release。
实例
public class SemaphoreDemo { static class Link { } static class ObjPool<T, R> { final List<T> pool; final Semaphore semaphore; ObjPool(int size, T t) { pool = new Vector<>(size); for (int i = 0; i < size; i++) { pool.add(t); } semaphore = new Semaphore(size); } public R exec(Function<T, R> func) throws Exception { T t = null; semaphore.acquire(); try { System.out.println(Thread.currentThread().getName() + "---------争夺锁--------"); t = pool.remove(0); System.out.println(Thread.currentThread().getName() + " 拿到锁执行"); return func.apply(t); } finally { pool.add(t); semaphore.release(); } } } public static void main(String[] args) { ObjPool objPool = new ObjPool(5, new Link()); for (int i = 0; i < 30; i++) { new Thread(() -> { try { objPool.exec(t -> t.toString()); } catch (Exception e) { } }).start(); } } }
以上就是java使用Semaphore实现限流器的方法,希望对大家有所帮助。更多Java学习指路:Java基础
本教程操作环境:windows7系统、java10版,DELL G3电脑。
更新于:1个月前赞一波!4
相关文章
- 【说站】java中enumerate()的复制
- 【说站】java线程锁死是什么
- 【说站】java调用shell脚本的方法
- 【说站】java多线程的作用
- 【说站】java中ThreadGroup如何创建
- 【说站】java中RMI的原理分析
- 【说站】java继承中有哪些注意点
- 【说站】java内存间交互规则
- 【说站】java RabbitMQ消息队列是什么
- 【说站】java中jni是什么
- 【说站】java中有哪些特殊monitor
- 【说站】java引发死锁的四种情况
- 【说站】java setPriority()设置优先级
- 【说站】java isInterrupted()如何判断线程
- 【说站】java interrupt()打断阻塞的操作
- 【说站】java yield()和sleep()的区别
- 【说站】java中使用全局变量终止线程
- 【说站】java中UDP如何发送数据
- 【说站】java UDP通信的原理
- 【说站】java泛型接口的使用注意
文章评论
评论问答