在某些情况下,我需要驱逐
Java集合中最早的元素.该集合使用
LinkedHashSet
实现,这使得简单:只是摆脱集合迭代器返回的第一个元素:
- Set<Foo> mySet = new LinkedHashSet<Foo>();
- // do stuff...
- if (mySet.size() >= MAX_SET_SIZE)
- {
- Iterator<Foo> iter = mySet.iterator();
- iter.next();
- iter.remove();
- }
这是丑陋的:3行做一些我可以做的1行,如果我使用SortedSet(由于其他原因,SortedSet不是一个选项)
- if (/*stuff*/)
- {
- mySet.remove(mySet.first());
- }
那么有没有更清洁的方法呢?
>改变Set的实现,或者
写一个静态的实用方法?
我完全知道集合没有固有的顺序.我要求删除由迭代顺序定义的第一个条目.