Java实现流控-Semaphore-阿里云开发者社区

开发者社区> 开发与运维> 正文

Java实现流控-Semaphore

简介: 网上类似文章很多,不多说,直接上代码: /** * 流控类(Semaphore实现) * * @author ln * */ public class FlowControl { /** * 最大访...

网上类似文章很多,不多说,直接上代码:

/**
 * 流控类(Semaphore实现)
 * 
 * @author ln
 *
 */
public class FlowControl {

	/**
	 * 最大访问量
	 */
	private static final int MAX_ACCESS_COUNT = 20;

	/**
	 * 只能有MAX_ACCESS_COUNT个线程数同时访问
	 */
	private static final Semaphore semaphore = new Semaphore(MAX_ACCESS_COUNT);

	public static void main(String[] args) {
		// 线程池
		ExecutorService exec = Executors.newCachedThreadPool();

		// 模拟30个客户端
		for (int i = 0; i < 30; i++) {
			Runnable run = new Runnable() {
				@Override
				public void run() {
					try {
						// 1秒钟内得不到许可,则丢弃访问。
						if (semaphore.tryAcquire(1, TimeUnit.SECONDS)) {
							System.out.println("正在执行...");
							//做一些事情...
							Thread.sleep(2 * 1000);
							System.out.println("执行完毕!");
						} else {
							System.out.println("访问被拒绝!!!");
						}
					} catch (InterruptedException e) {
						e.printStackTrace();
					} finally {
						// 执行完成,释放许可。
						semaphore.release();
					}
				}
			};
			exec.execute(run);
		}

		// 关闭线程池
		exec.shutdown();
	}
}



版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
开发与运维
使用钉钉扫一扫加入圈子
+ 订阅

集结各类场景实战经验,助你开发运维畅行无忧

其他文章