集合的通用遍历方式

集合的通用遍历方式:

1.迭代器
2.增强for循环
3.foreach方法

增强for循环内部原理就是iterator迭代器,foreach方法源码调用了增强for循环。

public class CollectionTest2 {
    public static void main(String[] args) {
        //以多态的形式创建集合对象,调用单例集合中的共有方法
        /*
        public boolean hasNext​() 如果迭代具有更多元素,则返回 true 。
        public E next​() 返回迭代中的下一个元素。
         */
        Collection<Student> c=new ArrayList<>();
        c.add(new Student("张三",18));
        c.add(new Student("李四",22));
        c.add(new Student("王五",25));

        //1.获取迭代器
        Iterator<Student> it = c.iterator();

        //2.循环判断,集合中是否还有元素
        while (it.hasNext()){
            //3.调用next方法,将元素取出
            Student stu = it.next();
            System.out.println(stu);
        }
        //总结:hashNext():判断集合中是否还有元素
        //next():取出集合元素,并将指针向后移动 注意:在循环过程中,next方法最好只调用一次

        /*
        增强for循环
        简化迭代器的代码书写,内部原理就是iterator迭代器
         */
        System.out.println("---------------------");
        for (Student stu:c){
            System.out.println(stu);
        }

        /*
        foreach方法遍历集合
         */
        System.out.println("----------------");
        c.forEach(new Consumer<Student>() {
            @Override
            public void accept(Student student) {
                System.out.println(student);
            }
        });
        System.out.println("----------------");
        //lambda表现形式
        c.forEach(student -> System.out.println(student));

    }
}

输出结果:

Student{name = 张三, age = 18}
Student{name = 李四, age = 22}
Student{name = 王五, age = 25}
---------------------
Student{name = 张三, age = 18}
Student{name = 李四, age = 22}
Student{name = 王五, age = 25}
----------------
Student{name = 张三, age = 18}
Student{name = 李四, age = 22}
Student{name = 王五, age = 25}
----------------
Student{name = 张三, age = 18}
Student{name = 李四, age = 22}
Student{name = 王五, age = 25}

Process finished with exit code 0

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,我可以为你介绍一下如何设计一个通用集合类的函数模板。 首先,我们需要确定集合类应该具有的基本操作。通常,集合类应该支持以下操作: - 添加元素 - 删除元素 - 判断元素是否存在 - 获取集合大小 - 迭代器遍集合 然后,我们考虑如何使用模板来实现这些操作。我们可以使用模板参数来指定集合元素的类型,例如: ```cpp template<typename T> class Set { public: void add(const T& element); void remove(const T& element); bool contains(const T& element) const; int size() const; // ... private: // ... }; ``` 这里,`T` 是集合元素的类型,`add` 函数用于添加元素,`remove` 函数用于删除元素,`contains` 函数用于判断元素是否存在,`size` 函数用于获取集合大小。我们还可以添加其他操作,例如 `begin` 和 `end` 函数用于返回迭代器。 在实现具体的操作时,我们可以使用标准库中的容器来存储集合元素。例如,可以使用 `std::set` 来实现 `Set` 类的基本操作: ```cpp template<typename T> class Set { public: void add(const T& element) { m_set.insert(element); } void remove(const T& element) { m_set.erase(element); } bool contains(const T& element) const { return m_set.find(element) != m_set.end(); } int size() const { return m_set.size(); } // ... private: std::set<T> m_set; }; ``` 这里,`m_set` 是一个私有成员变量,用于存储集合元素。 使用这个函数模板,我们可以创建一个通用集合类,例如: ```cpp Set<int> mySet; mySet.add(1); mySet.add(2); mySet.add(3); if (mySet.contains(2)) { mySet.remove(2); } ``` 这样,我们就可以使用一个通用集合类来存储不同类型的元素了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值