我有一个带有队列对象的hashmap,并且我希望每次查看一个对象时都可以按它们位于队列中的顺序来查看不同队列中的不同对象,通常是消费者-生产者问题。

public class MainQueue {

    public static Map<Integer, SingleQueue> list = new ConcurrentHashMap<>();

    public MainQueue() {

    }

    public Map getQueue() {
        return this.list;
    }

    public void addToMainQueue(SendObject sfo) {
        int ohashcode = sfo.hashCode();
        if (!list.containsKey(ohashcode)) {
            list.put(ohashcode, new SingleQueue());
            list.get(ohashcode).addQueue(sfo);
        } else {
            list.get(ohashcode).addQueue(sfo);
        }

    }

    public SendObject getFromQueue() {

        ???
        return TempFax;
    }
}

---------HashMap-------------

423532,queue1:{1,2,3,4,5,6,7,8,9}

564898,queue2:{a,b,c,d,e}

039894,queue3:{x,y,z}


当我调用getFromQueue函数时,它应该返回“ 1”
我打电话后,返回“ a”
我打电话后,返回“ x”

finally= 1,a,x,2,b,y,3,c,z,4,d,5,e,6,7,8,9


我怎样才能做到这一点?

最佳答案

根据您的问题,您有兴趣按FIFO顺序检索这些元素,并且需要某种方式将它们分组为哈希码。

我建议将那些SendObject添加到单个队列(如LinkedList )中,这样您就可以逐一轮询()这些元素。

如果您需要某种方式将不同的项目分组为类别(或您的案例中的哈希码),则可以在SendObject中添加一个Category字段,以便跟踪这些内容。

07-28 01:54
查看更多