java - 如何通过 ThreadExecutor 实现带有自定义比较器的 BlockingQueue?

标签 java multithreading executorservice blockingqueue

我正在尝试根据字符串长度按升序运行任务。但是它没有按预期工作。这是我迄今为止尝试过的代码:

import java.util.Comparator;
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.PriorityBlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;

public class PriorityQueueTest {
    public static void main(String... args) throws InterruptedException {
        BlockingQueue<Runnable> pq = new PriorityBlockingQueue<Runnable>(5,
                new PriorityQueueComparator());
        Runner r1 = new Runner("ABC");
        Runner r2 = new Runner("AB");
        Runner r3 = new Runner("ABCD");

        Runner[] arr = new Runner[] { r1, r2, r3 };

        ThreadPoolExecutor pool = new ThreadPoolExecutor(3, 3, 0,
                TimeUnit.SECONDS, pq);

        for (int i = 0; i < arr.length; i++) {
            pool.execute(arr[i]);
        }
        pool.shutdown();

    }
}

class PriorityQueueComparator<T extends Runner> implements Comparator<T> {

    public int compare(Runner o1, Runner o2) {
        if (o1.getName().length() < o2.getName().length()) {
            return 1;
        }
        if (o1.getName().length() > o2.getName().length()) {
            return -1;
        }
        return 0;
    }

}

class Runner implements Runnable {
    private String name;

    public Runner(String sname) {
        this.name = sname;
    }

    public void run() {
        System.out.println(name);
    }

    public String getName() {
        return name;
    }

}

我预计输出是

AB
ABC
ABCD

ABCD
ABC
AB

基于我的客户ComparatorcompareTo()方法?

我猜自定义比较器没有被调用。

请帮忙。

最佳答案

PriorityQueue 仅对当时队列中的任务进行排序。事实并非如此

  • 对已开始的任务进行排序。
  • 对尚未添加的任务进行排序。
  • 如果有多个线程,请更改任务完成的顺序。

如果您有少量短期任务和多个线程。您不应该期望看到太大的差异。

关于java - 如何通过 ThreadExecutor 实现带有自定义比较器的 BlockingQueue?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32305087/

相关文章:

java - Java中Connection对象什么时候会被清除?

c# - 为什么在 switch case 语句中只允许使用有限的类型

java - 在 JFrame 中使用线程

java - ExecutorService 并在关闭后等待其他任务完成时接受新任务

java - 关于ExecutorService的澄清

java - Spring 启动 : SpringBootServletInitializer is deprecated

java - 如何在 Log4j2 中使用 slf4j 的格式化消息

c# - Lazy<T> 是线程安全的惰性加载单例的良好解决方案吗?

multithreading - 工作池模式 - 死锁

java - ExecutorCompletionService 最多等待 n 秒完成