在某些情况下,我需要驱逐
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的实现,或者
写一个静态的实用方法?
我完全知道集合没有固有的顺序.我要求删除由迭代顺序定义的第一个条目.