0

IMap 的 localkeyset 是否已排序?或者,无论如何我可以代理要排序的支持数据结构?

我将临时密钥存储在 IMap 中,并且不时寻找最旧的本地密钥。到目前为止,我正在做一个新的 TreeSet(imap.localKeyset()),但是,我想知道是否可以让本地支持数据结构自行排序。

谢谢, 苏塔努

4

1 回答 1

0

不,localKeySet 没有排序,只是一个常规 Set。如果你想保持顺序,我宁愿使用 Queue 而不是 TreeMap(除非你想根据其他一些参数而不是 TimeStamp 来排序)并实现一个 localEntryListener 来控制这个 Queue。
另一种选择是使用 TreeSet。

public class HazelcastNode {

    private static Queue localEntryQueue = new LinkedList<>();

    public HazelcastNode(){
        HazelcastInstance hz = Hazelcast.newHazelcastInstance();

        hz.getMap("hzMap").addLocalEntryListener(new MyLocalMapListner());
    }

    public static void main(String[] args){

        HazelcastNode node = new HazelcastNode();

        //Get the Head of the queue which will be the oldest local entry
        HazelcastNode.localEntryQueue.peek();
    }

    private class MyLocalMapListner implements MapListener,EntryAddedListener,
            EntryRemovedListener,
            EntryUpdatedListener,
            EntryEvictedListener,
            EntryExpiredListener{

        @Override
        public void entryAdded(EntryEvent entryEvent) {
            HazelcastNode.localEntryQueue.add(entryEvent.getKey());
        }

        @Override
        public void entryEvicted(EntryEvent entryEvent) {
            HazelcastNode.localEntryQueue.remove(entryEvent.getKey());
        }

        @Override
        public void entryExpired(EntryEvent entryEvent) {
            HazelcastNode.localEntryQueue.remove(entryEvent.getKey());
        }

        @Override
        public void entryRemoved(EntryEvent entryEvent) {
            HazelcastNode.localEntryQueue.remove(entryEvent.getKey());
        }

        @Override
        public void entryUpdated(EntryEvent entryEvent) {
        }
    }
}
于 2016-06-25T06:00:59.833 回答