java – 从集合中删除“第一个”对象

在某些情况下,我需要驱逐 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的实现,或者
一个静态的实用方法

使用Guava的任何解决方案都是可以的.

我完全知道集合没有固有的顺序.我要求删除由迭代顺序定义的第一个条目.

解决方法

LinkedHashSet是LinkedHashMap的包装器,它支持简单的“删除最旧”策略.使用它作为一套你可以做
Set<String> set = Collections.newSetFromMap(new LinkedHashMap<String,Boolean>(){
    protected boolean removeEldestEntry(Map.Entry<String,Boolean> eldest) {
        return size() > MAX_ENTRIES;
    }
});

相关文章

最近看了一下学习资料,感觉进制转换其实还是挺有意思的,尤...
/*HashSet 基本操作 * --set:元素是无序的,存入和取出顺序不...
/*list 基本操作 * * List a=new List(); * 增 * a.add(inde...
/* * 内部类 * */ 1 class OutClass{ 2 //定义外部类的成员变...
集合的操作Iterator、Collection、Set和HashSet关系Iterator...
接口中常量的修饰关键字:public,static,final(常量)函数...