minecraft-src/net/minecraft/util/thread/StrictQueue.java
2025-07-04 01:41:11 +03:00

112 lines
2.3 KiB
Java

package net.minecraft.util.thread;
import com.google.common.collect.Queues;
import java.util.Locale;
import java.util.Queue;
import java.util.concurrent.atomic.AtomicInteger;
import org.jetbrains.annotations.Nullable;
public interface StrictQueue<T, F> {
@Nullable
F pop();
boolean push(T value);
boolean isEmpty();
int size();
public static final class FixedPriorityQueue implements StrictQueue<StrictQueue.IntRunnable, Runnable> {
private final Queue<Runnable>[] queues;
private final AtomicInteger size = new AtomicInteger();
public FixedPriorityQueue(int size) {
this.queues = new Queue[size];
for (int i = 0; i < size; i++) {
this.queues[i] = Queues.<Runnable>newConcurrentLinkedQueue();
}
}
@Nullable
public Runnable pop() {
for (Queue<Runnable> queue : this.queues) {
Runnable runnable = (Runnable)queue.poll();
if (runnable != null) {
this.size.decrementAndGet();
return runnable;
}
}
return null;
}
public boolean push(StrictQueue.IntRunnable value) {
int i = value.priority;
if (i < this.queues.length && i >= 0) {
this.queues[i].add(value);
this.size.incrementAndGet();
return true;
} else {
throw new IndexOutOfBoundsException(String.format(Locale.ROOT, "Priority %d not supported. Expected range [0-%d]", i, this.queues.length - 1));
}
}
@Override
public boolean isEmpty() {
return this.size.get() == 0;
}
@Override
public int size() {
return this.size.get();
}
}
public static final class IntRunnable implements Runnable {
final int priority;
private final Runnable task;
public IntRunnable(int priority, Runnable task) {
this.priority = priority;
this.task = task;
}
public void run() {
this.task.run();
}
public int getPriority() {
return this.priority;
}
}
public static final class QueueStrictQueue<T> implements StrictQueue<T, T> {
private final Queue<T> queue;
public QueueStrictQueue(Queue<T> queue) {
this.queue = queue;
}
@Nullable
@Override
public T pop() {
return (T)this.queue.poll();
}
@Override
public boolean push(T value) {
return this.queue.add(value);
}
@Override
public boolean isEmpty() {
return this.queue.isEmpty();
}
@Override
public int size() {
return this.queue.size();
}
}
}