java – 使用包含或循环通过列表之间有什么大的区别?

性能明智,使用之间真的有很大的区别:

> ArrayList.contains(o)vs foreach | iterator
> LinkedList.contains(o)vs foreach | iterator

当然,对于foreach | iterator循环,我必须明确比较方法并相应地返回true或false.

我正在比较的对象是equals()和hashcode()都被正确覆盖的对象.

编辑:毕竟不需要知道关于containsValue,不好意思.是的,我很愚蠢…我意识到我的问题是关于containsKey vs foreach的愚蠢,我不知道我在想什么.我基本上想知道上面的(编辑出来的其他).

解决方法

编辑:

随着问题的新形式不再包含HashMap和TreeMap,我的答案是完全不同的.我现在说不.

我确信其他人已经回答了这一点,但是在LinkedList和ArrayList中,contains()只是调用indexOf(),它遍历集合.

有可能在LinkedList和ArrayList之间以及包含和foreach之间存在微小的性能差异,没有任何大的差异.

相关文章

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