fallback to no threading if on single-core :[

This commit is contained in:
dags- 2020-03-21 00:11:37 +00:00
parent 3668026953
commit 1963a388a7
1 changed files with 42 additions and 9 deletions

View File

@ -27,6 +27,7 @@ package com.terraforged.core.util.concurrent;
import com.terraforged.core.util.concurrent.batcher.AsyncBatcher; import com.terraforged.core.util.concurrent.batcher.AsyncBatcher;
import com.terraforged.core.util.concurrent.batcher.Batcher; import com.terraforged.core.util.concurrent.batcher.Batcher;
import com.terraforged.core.util.concurrent.batcher.SyncBatcher;
import java.util.concurrent.Callable; import java.util.concurrent.Callable;
import java.util.concurrent.Executor; import java.util.concurrent.Executor;
@ -35,13 +36,12 @@ import java.util.concurrent.ForkJoinTask;
public class ThreadPool implements Executor { public class ThreadPool implements Executor {
private static final ThreadPool instance = new ThreadPool("TF", defaultPoolSize()); private static final ThreadPool instance = create("TF", defaultPoolSize());
private static final Object lock = new Object();
private final ForkJoinPool service; private final ForkJoinPool service;
private ThreadPool(String name, int size) { private ThreadPool(ForkJoinPool service) {
this.service = ThreadPool.createPool(size, name); this.service = service;
} }
@Override @Override
@ -49,7 +49,7 @@ public class ThreadPool implements Executor {
service.submit(command); service.submit(command);
} }
public <T> ForkJoinTask<?> submit(Runnable runnable) { public ForkJoinTask<?> submit(Runnable runnable) {
return service.submit(runnable); return service.submit(runnable);
} }
@ -65,8 +65,15 @@ public class ThreadPool implements Executor {
return instance; return instance;
} }
public static ThreadPool create(int size) { public static ThreadPool create(String name, int size) {
return new ThreadPool("Pool", Math.max(1, size)); if (size < 2) {
return new SingleThreadExecutor();
}
return new ThreadPool(createPool(name, size));
}
public static ForkJoinPool createPool(String name, int size) {
return new ForkJoinPool(size, new WorkerFactory.ForkJoin(name), null, true);
} }
private static int defaultPoolSize() { private static int defaultPoolSize() {
@ -74,8 +81,34 @@ public class ThreadPool implements Executor {
return Math.max(1, (int) ((threads / 3F) * 2F)); return Math.max(1, (int) ((threads / 3F) * 2F));
} }
public static ForkJoinPool createPool(int size, String name) { private static class SingleThreadExecutor extends ThreadPool {
return new ForkJoinPool(size, new WorkerFactory.ForkJoin(name), null, true); private SingleThreadExecutor() {
super(null);
}
@Override
public void execute(Runnable command) {
command.run();
}
@Override
public ForkJoinTask<?> submit(Runnable runnable) {
ForkJoinTask<?> task = ForkJoinTask.adapt(runnable);
task.invoke();
return task;
}
@Override
public <T> ForkJoinTask<T> submit(Callable<T> callable) {
ForkJoinTask<T> task = ForkJoinTask.adapt(callable);
task.invoke();
return task;
}
@Override
public Batcher batcher(int size) {
return new SyncBatcher();
}
} }
} }