原文地址:http://blog.csdn.net/zq602316498/article/details/39163899
在 JDK1.5 之后,至少有三种遍历的方式:ForEach、迭代器、for循环性能比较
- package bupt.xiaoye.charpter2.list;
- import java.util.ArrayList;
- import java.util.Iterator;
- import java.util.List;
- public class TestFor {
- public static void testForEach(List list) {
- Object temp;
- for(Object t : list)
- temp = t;
- }
- public static void testFor(List list) {
- Object temp;
- for (int i = 0; i < 1000000; i++) {
- temp = list.get(i);
- }
- }
- public static void testIterator(List list) {
- Object temp;
- for(Iterator<Object> it = list.iterator();it.hasNext();){
- temp = it.next();
- }
- }
- public static void main(String[] args) {
- Object obj = new Object();
- List list = new ArrayList();
- for (int i = 0; i < 1000000; i++) {
- list.add(obj);
- }
- testFor(list);
- testForEach(list);
- testIterator(list);
- }
- }
运行结果为:
可以看到,直接for循环效率最高,其次是迭代器和 ForEach操作。
作为语法糖,其实 ForEach 编译成 字节码之后,使用的是迭代器实现的,反编译后,testForEach方法如下:
- public static void testForEach(List list) {
- for (Iterator iterator = list.iterator(); iterator.hasNext();) {
- Object t = iterator.next();
- Object obj = t;
- }
- }
可以看到,只比迭代器遍历多了生成中间变量这一步,因为性能也略微下降了一些。
原文地址:http://blog.csdn.net/zq602316498/article/details/39163899
相关推荐
2. **迭代器的使用**:如果迭代器本身有额外的计算或状态管理,`foreach`可能比`for`慢。 3. **循环控制**:`for`循环可以方便地跳过或提前结束循环,而`foreach`则不太容易实现这样的控制,这可能导致`for`在某些...
foreach 循环实际上还是用的普通的 for 循环,对于数组来说,而对于集合来说,foreach 循环实际上是用的 iterator 迭代器迭代。 在 Java 中,foreach 循环可以用来遍历数组和集合,例如: ```java int [] array = ...
`GetEnumerator`方法实际上是一个迭代器,当被外部代码(如foreach循环)调用时,会返回一个`IEnumerator<int>`对象,该对象可以通过`MoveNext()`和`Current`属性遍历序列。 在我们的“迭代器Demo”项目中,可能...
ES6引入的`for...of`循环则可以配合迭代器遍历数组,同时支持中断循环: ```javascript let arr = [1, 2, 3]; for (let item of arr) { console.log(item); if (item === 2) break; } ``` `map()`方法创建一个新...
例如,在`ArrayList`中,使用传统的`for`循环通常比使用`Iterator`更快,而`foreach`循环则介于两者之间。然而,在`LinkedList`等其他类型的集合中,`Iterator`的性能表现可能会优于传统的循环结构。 综上所述,`...
迭代器通常用于实现`IEnumerable`接口,这样其他代码可以通过`foreach`循环轻松地遍历数据: ```csharp public IEnumerable<int> GetNumbers() { for (int i = 1; i ; i++) { yield return i; } } ``` 在这个...
然而,当涉及到动态数据结构,如 `ArrayList` 或自定义集合,`foreach` 可能具有更好的性能,因为它是由编译器生成的迭代器,可以避免显式的索引操作。 3. **易用性**: - **无需关心数组起始索引**:`foreach` 不...
5. **安全性**:`foreach`循环不会意外改变遍历的集合,因为它不暴露集合的内部迭代器,从而降低了意外修改集合的风险。 6. **可读性**:`foreach`循环使得代码的意图更加清晰,因为它直接表示了“对于集合中的每个...
在C#编程语言中,`foreach`循环是一个非常重要的语法结构,它用于遍历集合、数组或其他可迭代对象中的元素。这个压缩包文件"foreach测试.rar"可能包含了一些示例代码,用于展示`foreach`循环的工作原理和最佳实践。...
迭代器模式在JavaScript中的应用广泛,比如在ES6中引入的`for...of`循环,它就是一个内置的迭代器。此外,`Array.prototype.forEach()`、`Map`和`Set`等原生API也使用了迭代器原理。 使用迭代器模式的优点包括: - ...
`foreach`循环依赖于`IEnumerable`接口,这意味着在迭代过程中,它会调用`GetEnumerator`方法来获取迭代器。每次迭代时,迭代器的`MoveNext`方法被调用来获取下一个元素。值得注意的是,`foreach`在循环开始时只会...
在某些情况下,还可以利用数组的迭代器方法,如JavaScript的`Array.prototype.forEach()`或`for...of`循环,它们在内部已经进行了优化,但要注意这些方法可能并不适合所有场景,特别是当涉及到复杂的条件判断或需要...
理论上,我们也可以通过实现Iterator接口的方式实现迭代器,但这样做往往比较繁琐。生成器通过yield简化了这一过程,并且具有更好的性能。例如,如果我们使用迭代器遍历一个巨大的数据集,那么整个数据集就需要加载...
在JavaScript的世界里,ES6(ECMAScript 2015)引入了许多新的特性,其中迭代器(Iterator)和`for...of`循环是两个重要的概念。这些特性极大地提升了JavaScript处理数据结构的能力,使得开发者可以更加优雅地遍历...
然而,在C++或Java等语言中,foreach循环可能会有额外的开销,因为它需要创建迭代器对象。 5. **递归循环**:递归是一种函数或方法调用自身的技术,可以用来解决一些复杂问题。虽然递归在概念上很强大,但其速度...
另一方面,foreach循环通常会利用内置的迭代器,其速度依赖于数据结构的实现。 在“循环语句的用法之速度比较”这个项目中,作者可能通过编写和测试各种循环结构的易语言源码,分析了它们在处理相同任务时的运行...
6. **迭代器和生成器**:在Python中,迭代器允许以迭代方式访问容器对象,而生成器则是一种惰性计算的迭代器,节省内存。它们提供了更高效的循环方式,特别是处理大数据集时: ```python generator = (x for x in ...
C#中的yield使用一个简单的for循环来演示,如下所示: ```csharp using System.Collections; class Program { public static IEnumerable Fibonacci(int n) { int cur = 1; int prev = 0; for (int i = 0; i ...
- **增强型for循环(foreach)**:简化了遍历集合和数组的过程,使代码更加简洁。 - **死循环**:如果循环条件始终为真,或者没有适当的退出机制,就会形成死循环。理解如何避免和处理死循环是编程的基本技能。 - ...
1. **for循环**:for循环是最常用的循环结构之一,它适用于已知循环次数的情况。在Python中,for循环常用于遍历序列(如列表或字符串): ```python for item in sequence: # 执行代码块 ``` 2. **while循环**...