I\'ve searched a lot but couldn\'t find any solution. I use java thread pool in such way:
ExecutorService c = Executors.newFixedThreadPool(3);
for (int i = 0
You can use PriorityBlockingQueue to specify Queue to ThreadPoolExecutor.
public class PriorityExecutor extends ThreadPoolExecutor {
public PriorityExecutor(int corePoolSize, int maximumPoolSize,
long keepAliveTime, TimeUnit unit, BlockingQueue workQueue) {
super(corePoolSize, maximumPoolSize, keepAliveTime, unit, workQueue);
}
//Utitlity method to create thread pool easily
public static ExecutorService newFixedThreadPool(int nThreads) {
return new PriorityExecutor(nThreads, nThreads, 0L,
TimeUnit.MILLISECONDS, new PriorityBlockingQueue());
}
//Submit with New comparable task
public Future> submit(Runnable task, int priority) {
return super.submit(new ComparableFutureTask(task, null, priority));
}
//execute with New comparable task
public void execute(Runnable command, int priority) {
super.execute(new ComparableFutureTask(command, null, priority));
}
}
Define ComparableFutureTask to compare on Priority.
class ComparableFutureTask extends FutureTask
implements
Comparable> {
volatile int priority = 0;
public ComparableFutureTask(Runnable runnable, T result, int priority) {
super(runnable, result);
this.priority = priority;
}
public ComparableFutureTask(Callable callable, int priority) {
super(callable);
this.priority = priority;
}
@Override
public int compareTo(ComparableFutureTask o) {
return Integer.valueOf(priority).compareTo(o.priority);
}
}