对List的遍历有三种方式
List<String> list = new ArrayList<String>();
list.add("testone");
list.add(“testtwo”);
...
第一种:
for(Iterator<String> it = list.iterator(); it.hasNext(); ) {
....
}
这种方式在循环执行过程中会进行数据锁定, 性能稍差, 同时,如果你想在寻欢过程中去掉某个元素,只能调用it.remove方法, 不能使用list.remove方法, 否则一定出现并发访问的错误.
第二种:
for(String data : list) {
.....
}
内部调用第一种, 换汤不换药, 因此比Iterator 慢,这种循环方式还有其他限制, 不建议使用它。
第三种:
for(int i=0; i<list.size(); i++) {
A a = list.get(i);
...
}
内部不锁定, 效率最高, 但是当写多线程时要考虑并发操作的问题。
本文介绍了Java中遍历List的三种常见方法:迭代器、增强for循环和普通for循环,并对比了它们的性能特点及适用场景。迭代器在删除元素时较为安全,但效率较低;增强for循环内部调用迭代器,灵活性受限;普通for循环效率最高,但需注意多线程环境下的并发问题。
8093

被折叠的 条评论
为什么被折叠?



