Bounded executor service
This commit is contained in:
parent
bebff648b7
commit
2111b5bf34
@ -83,9 +83,13 @@ public class Client {
|
|||||||
throw new IllegalThreadStateException("Thread: " + Thread.currentThread().getName() + " trying receive incoming updates but shouldn't be called simultaneously from two different threads!");
|
throw new IllegalThreadStateException("Thread: " + Thread.currentThread().getName() + " trying receive incoming updates but shouldn't be called simultaneously from two different threads!");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int resultSize;
|
||||||
this.receiveLock.lock();
|
this.receiveLock.lock();
|
||||||
var resultSize = nativeClientReceive(this.clientId, eventIds, events, timeout);
|
try {
|
||||||
|
resultSize = nativeClientReceive(this.clientId, eventIds, events, timeout);
|
||||||
|
} finally {
|
||||||
this.receiveLock.unlock();
|
this.receiveLock.unlock();
|
||||||
|
}
|
||||||
|
|
||||||
for (int i = 0; i < resultSize; i++) {
|
for (int i = 0; i < resultSize; i++) {
|
||||||
responseList.add(new Response(eventIds[i], events[i]));
|
responseList.add(new Response(eventIds[i], events[i]));
|
||||||
|
@ -0,0 +1,24 @@
|
|||||||
|
package it.ernytech.tdlib.utils;
|
||||||
|
|
||||||
|
import java.util.concurrent.Callable;
|
||||||
|
import java.util.concurrent.ExecutorService;
|
||||||
|
import java.util.concurrent.Future;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
import java.util.function.BiConsumer;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
public interface BoundedExecutorService extends ExecutorService {
|
||||||
|
|
||||||
|
static BoundedExecutorService create(int maxQueueSize,
|
||||||
|
int corePoolSize,
|
||||||
|
int maxPoolSize,
|
||||||
|
long keepAliveTime,
|
||||||
|
TimeUnit unit,
|
||||||
|
@Nullable BiConsumer<Boolean, Integer> queueSizeStatus) {
|
||||||
|
return new BoundedExecutorServiceImpl(maxQueueSize, corePoolSize, maxPoolSize, keepAliveTime, unit, queueSizeStatus);
|
||||||
|
}
|
||||||
|
|
||||||
|
<T> Future<T> submitButBlockIfFull(Callable<T> task) throws InterruptedException;
|
||||||
|
|
||||||
|
void executeButBlockIfFull(Runnable task) throws InterruptedException;
|
||||||
|
}
|
@ -1,12 +1,11 @@
|
|||||||
package it.ernytech.tdlib.utils;
|
package it.ernytech.tdlib.utils;
|
||||||
|
|
||||||
import java.util.concurrent.locks.ReentrantLock;
|
|
||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
import java.util.concurrent.*;
|
import java.util.concurrent.*;
|
||||||
import java.util.function.BiConsumer;
|
import java.util.function.BiConsumer;
|
||||||
|
|
||||||
public class BoundedExecutor extends ThreadPoolExecutor {
|
class BoundedExecutorServiceImpl extends ThreadPoolExecutor implements BoundedExecutorService {
|
||||||
|
|
||||||
private final Semaphore semaphore;
|
private final Semaphore semaphore;
|
||||||
private final @Nullable BiConsumer<Boolean, Integer> queueSizeStatus;
|
private final @Nullable BiConsumer<Boolean, Integer> queueSizeStatus;
|
||||||
@ -22,7 +21,7 @@ public class BoundedExecutor extends ThreadPoolExecutor {
|
|||||||
* @param unit
|
* @param unit
|
||||||
* @param queueSizeStatus Status. The boolean indicates if the queue is full, the integer indicates the current queue size
|
* @param queueSizeStatus Status. The boolean indicates if the queue is full, the integer indicates the current queue size
|
||||||
*/
|
*/
|
||||||
public BoundedExecutor(int maxQueueSize,
|
public BoundedExecutorServiceImpl(int maxQueueSize,
|
||||||
int corePoolSize,
|
int corePoolSize,
|
||||||
int maxPoolSize,
|
int maxPoolSize,
|
||||||
long keepAliveTime,
|
long keepAliveTime,
|
||||||
@ -41,6 +40,7 @@ public class BoundedExecutor extends ThreadPoolExecutor {
|
|||||||
* Submits task to execution pool, but blocks while number of running threads
|
* Submits task to execution pool, but blocks while number of running threads
|
||||||
* has reached the bound limit
|
* has reached the bound limit
|
||||||
*/
|
*/
|
||||||
|
@Override
|
||||||
public <T> Future<T> submitButBlockIfFull(final Callable<T> task) throws InterruptedException {
|
public <T> Future<T> submitButBlockIfFull(final Callable<T> task) throws InterruptedException {
|
||||||
blockIfFull();
|
blockIfFull();
|
||||||
return submit(task);
|
return submit(task);
|
||||||
@ -50,6 +50,7 @@ public class BoundedExecutor extends ThreadPoolExecutor {
|
|||||||
* Submits task to execution pool, but blocks while number of running threads
|
* Submits task to execution pool, but blocks while number of running threads
|
||||||
* has reached the bound limit
|
* has reached the bound limit
|
||||||
*/
|
*/
|
||||||
|
@Override
|
||||||
public void executeButBlockIfFull(final Runnable task) throws InterruptedException {
|
public void executeButBlockIfFull(final Runnable task) throws InterruptedException {
|
||||||
blockIfFull();
|
blockIfFull();
|
||||||
execute(task);
|
execute(task);
|
||||||
@ -69,7 +70,7 @@ public class BoundedExecutor extends ThreadPoolExecutor {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void beforeExecute(Thread t, Runnable r) {
|
public void beforeExecute(Thread t, Runnable r) {
|
||||||
semaphore.release();
|
semaphore.release();
|
||||||
|
|
||||||
super.beforeExecute(t, r);
|
super.beforeExecute(t, r);
|
Loading…
x
Reference in New Issue
Block a user