java - 在Java中指定任务顺序执行

标签 java multithreading threadpool threadpoolexecutor

我搜索了很多,但找不到任何解决方案。 我以这种方式使用 java 线程池:

ExecutorService c = Executors.newFixedThreadPool(3);
for (int i = 0; i < 10; ++i) {
  c.execute(new MyTask(i));
}

以这种方式,任务按顺序执行(如在队列中)。但我需要改变“选择下一个任务”策略。所以我想分配给每个任务指定优先级(它不是线程优先级)并执行与这些优先级相对应的任务。因此,当执行者完成另一个任务时,它会选择下一个任务作为具有最高优先级的任务。 它描述了常见问题。也许有更简单的方法不考虑优先级。它选择最后添加的任务作为下一个执行而不是首先添加的任务。粗略地说FixedThreadPool使用FIFO策略。我可以使用后进先出策略吗?

最佳答案

您可以使用 PriorityBlockingQueue将 Queue 指定给 ThreadPoolExecutor。

public class PriorityExecutor extends ThreadPoolExecutor {

    public PriorityExecutor(int corePoolSize, int maximumPoolSize,
            long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> 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<Runnable>());
    }
    //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));
    }
}

定义 ComparableFutureTask 以比较优先级。

class ComparableFutureTask<T> extends FutureTask<T>
        implements
            Comparable<ComparableFutureTask<T>> {

    volatile int priority = 0;

    public ComparableFutureTask(Runnable runnable, T result, int priority) {
        super(runnable, result);
        this.priority = priority;
    }
    public ComparableFutureTask(Callable<T> callable, int priority) {
        super(callable);
        this.priority = priority;
    }
    @Override
    public int compareTo(ComparableFutureTask<T> o) {
        return Integer.valueOf(priority).compareTo(o.priority);
    }
  }

关于java - 在Java中指定任务顺序执行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12722396/

相关文章:

java - 比较 java 中的 Long 值

java - 如何检查 jar 文件依赖性

java - 如何解决 "Connect: operation timed out"和 "RetryExec"错误?

java - TheadFactoryBuilder生成的ThreadFactory线程安全吗?

java - CDI 是否为 RequestScoped 重用代理?

c# - WCF 服务是否使用多线程来处理传入请求?

java - Scala Collections - 使用转换器将 Any 类型转换为 Seq[T]

java - 访问 ArrayList<ArrayList<SomeObject>> 元素

python - 扭曲: `defer.execute` 和 `threads.deferToThread` 之间的区别

c++ - 当销毁包含该线程的对象时,线程在自身上调用 thread.detach()