1、释放20个信号
Semaphore semaphore = new Semaphore(20);
2、获取信号
semaphore.acquire();
3、释放信号
semaphore.release();
4、还有信号没有释放,线程休眠1秒钟
//查看当前可用许可数,等于concurrency结束
while (semaphore.availablePermits() != concurrency){
Thread.sleep(1000);
}
第二步和第三步放到循环中。
如果有一千条数据,那么前20个数据可以获取到信号量,第21个信号只能等第一个信号被释放才能获取信号。
可以保证执行中的数据只有20条。
数据处理逻辑放到第2步和第3步中间