当前位置:   article > 正文

集合04/集合元素的遍历_delphi 遍历集合中的元素

delphi 遍历集合中的元素

集合元素的遍历


1.iterator接口
2. foreach


1. 使用迭代器Iterator接口

iterator():返回Iterator接口的实例,用于遍历集合元素。放在IteratorTest.java中测试

在这里插入图片描述


内部的方法: hasNext()和next()

package com.jh;

import org.junit.Test;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;

public class IteratorTest {
   

    @Test
    public void test1(){
   
        Collection coll = new ArrayList();
        coll.add(123);
        coll.add(456);
        coll.add(new Person("Jerry",20));
        coll.add(new String("Tom"));
        coll.add(false);

        Iterator iterator = coll.iterator();

        //方式一:不可取
//        System.out.println(iterator.next());
//        System.out.println(iterator.next());
//        System.out.println(iterator.next());
//        System.out.println(iterator.next());
//        System.out.println(iterator.next());//写多了报异常

        //方式二:不推荐
//        for (int i = 0;i < coll.size();i++){
   
//            System.out.println(iterator.next());
//        }

        //方式三:推荐
        //hasNext()∶判断是否还有下一个元素
        while(iterator.hasNext()){
   
            System.out.println(iterator.next());
        }
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44

结果
在这里插入图片描述

在这里插入图片描述

迭代器执行原理
显而易见,iterator对象相当于一个指针,指向第一个元素的上方空白位置。hasNext()判断下一个位置是否有元素,有则返回true,next()则是先将指针下移一位并返回所指的元素。

注:
iterator只是用于遍历,不是容器,因此调用iterator并不是生成一个与原来coll相同的结构


错误写法

package com.jh;

import org.junit.Test;

import java.util.ArrayList;
  • 1
  • 2
  • 3
  • 4
  • 5
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/201931?site
推荐阅读
相关标签
  

闽ICP备14008679号