集合

集合框架

一、Collection

1.定义方法:

Collection<E> obj = new Collection子类<>();

因为Collection是一个抽象类,所以不可以直接new Collection对象。

2.方法:

3.注意:

(1).Collection接口上又成就了两个接口list和set,list接口允许添加重复内容,永远返回true,set接口不允许添加重复内容,有可能返回false。

(2)因为所有的集合都实现了Collection接口,所以Collection的方法,其他集合都可以正常使用

二、迭代器

(1)迭代器的作用。

因为在很多情况下,需要完成对集合的遍历,这种情况下如果使用普通的for语句,将不能够实现这个目的,因为实现set接口的集合类是不存在索引且不允许重复的,这种情况下是无法使用普通的for语句遍历的。针对这个特殊的情况,迭代器产生了。

(2)迭代器工作原理。

实现Collection接口的所有集合获取元素的通用方式是——判断该集合是否存在下一个元素,如果有则访问下一个;如果没有,则遍历完成。

(3)Iterator<E>

Iterator<E>就是一个迭代器。

迭代器也是有泛型的(Iterator<E> 中的 E),集合是什么泛型,集合返回的迭代器就是什么泛型。

它有如下几个方法:

其中 hasNext() 方法负责检测集合是否遍历完成,next() 方法用于指向下一个元素,remove 方法负责移除指定元素。

(4)如何获取迭代器?

因为 Iterator<E> 是一个接口,所以不能直接New对象,而需要实现类对象。

Collector有一个方法 iterator() 方法,可以返回一个迭代器的实现对象。

(5)迭代器如何使用?

①从集合获取迭代器实现类对象。

②使用hasNext()方法判断是否还存在元素。

③遍历元素。

Iterator<E> iterator = 集合.iterator();

while(iterator.hasNext()){

......

}

(6)代码:

Stu类:

package com.lanyue.day11;

public class Stu {

public int age;

    public String name;

public Stu(int age, String name) {

        this.age = age;

        this.name = name;

    }

public int getAge() {

        return age;

    }

public void setAge(int age) {

        this.age = age;

    }

public String getName() {

        return name;

    }

public void setName(String name) {

        this.name = name;

    }

}

运行代码:

package com.lanyue.day11;

import java.util.ArrayList;

import java.util.Collection;

import java.util.Iterator;

public class CollectionLearn {

public static void main(String[] args) {

Collection<Stu> stus = new ArrayList<Stu>();

        stus.add(new Stu(20,"张三"));

        stus.add(new Stu(32,"李四"));

        stus.add(new Stu(23,"赵六"));

Iterator<Stu> iterator = stus.iterator();

        while(iterator.hasNext()){

Stu stu = iterator.next();

            System.out.println(stu.age + " " + stu.name);

        }

    }

}

三、增强for

jdk1.5以后,官方推出了增强版的for语句。专门用来遍历数组和集合。它的内部实现原理也是用迭代器实现的,只不过为了简化代码,采用for语句写法。

写法如下:

for(集合或数组  对象 :集合或数组){

//对 对象进行访问

注意:

增强for循环的目标操作数只能是数组或者集合。

Java第十四天,集合、迭代器的使用的更多相关文章

  1. “全栈2019”Java第九十四章:局部内部类详解

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  2. “全栈2019”Java第十四章:二进制、八进制、十六进制

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  3. “全栈2019”Java第二十四章:流程控制语句中决策语句switch下篇

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  4. java基础(十四)集合(一)

    这里有我之前上课总结的一些知识点以及代码大部分是老师讲的笔记 个人认为是非常好的,,也是比较经典的内容,真诚的希望这些对于那些想学习的人有所帮助! 由于代码是分模块的上传非常的不便.也比较多,讲的也是 ...

  5. Java系列学习(十四)-集合

    1.java中的集合学习 2.Collection中常用方法 1.添加功能 boolean add(E e):添加一个元素 boolean addAll(Collection<? extends ...

  6. 学JAVA第二十四天,Set集合与StringBuilder

    下面的内容需要慢慢看,因为,我的语言表达能力不是很好 首先说Set把,Set集合是一个无序且不允许重复的集合,而且查找效率也是快的可怕的. 但是,有些时候,我们必须要用储存多个相同的值时,Set也是可 ...

  7. 复习java基础第四天(集合:List、Map、Collections、Enumeration)

    一.List: List 代表一个元素有序.且可重复的集合,集合中的每个元素都有其对应的顺序索引 List 允许使用重复元素,可以通过索引来访问指定位置的集合元素. List 默认按元素的添加顺序设置 ...

  8. JAVA提高十四:HashSet深入分析

    前面我们介绍了HashMap,Hashtable,那么还有一个hash家族,那就是HashSet;在讲解HashSet前,大家先要知道的是HashSet是单值集合的接口,即是Collection下面的 ...

  9. JAVA基础第四章-集合框架Collection篇

    业内经常说的一句话是不要重复造轮子,但是有时候,只有自己造一个轮子了,才会深刻明白什么样的轮子适合山路,什么样的轮子适合平地! 我将会持续更新java基础知识,欢迎关注. 往期章节: JAVA基础第一 ...

随机推荐

  1. Mac OS X 10.13上 安装odoo 11.0开发环境

    0.准备假设homebrew已经安装好没安装的需要先安装,见下面链接http://brew.sh/ 1.安装PostgreSQL$ brew tap homebrew/services$ brew i ...

  2. (转)C代码优化方案

    C代码优化方案 原文地址:http://www.uml.org.cn/c++/200811103.asp 目录 C代码优化方案 1.选择合适的算法和数据结构 2.使用尽量小的数据类型 3.减少运算的强 ...

  3. 后端程序员必备:书写高质量SQL的30条建议

    前言 本文将结合实例demo,阐述30条有关于优化SQL的建议,多数是实际开发中总结出来的,希望对大家有帮助. 1.查询SQL尽量不要使用select *,而是select具体字段. 反例子: sel ...

  4. 网络安全从入门到精通 (第二章-1) Web安全前端基础

    本文内容: 前端是什么? 前端代码 HTML CSS JS !!!醋成酒的小墨,促成就的小墨,小墨促成就,!!! 1,前端是什么? 网站一般用两部分组成,前端负责展示,后端负责处理请求. 2,前端代码 ...

  5. [Dynamic Programming]动态规划之背包问题

    动态规划之背包问题 例题 现有4样物品n = ['a', 'b', 'c', 'd'],重量分别为w = [2, 4, 5, 3],价值分别为v = [5, 4, 6, 2].背包最大承重c = 9. ...

  6. mybatis3.2.7应用_高级映射(一对一、一对多、多对多)

    1. 一对一查询 需求:查询订单信息,关联查询创建订单的用户信息 1.1 使用resultType实现 1.1.1 sql语句 确定查询的主表:订单表       确定查询的关联表:用户表      ...

  7. Js遍历数组总结

    Js遍历数组总结 遍历数组的主要方法为for.forEach.map.for in.for of for var arr = [1,2,3,4,5]; var n = arr.length; // 直 ...

  8. vue你真棒

    引子:什么是前后端分离和前后端不分离? 前后端分离指的是后端开发人员只负责用来书写后端逻辑代码,不用再去管前端页面的搭建,前端人员只负责做好前端页面效果,不用管数据,数据直接向后端人员要,后端和前端通 ...

  9. Contest 156

    2019-09-29 14:56:09 总体感受:30min解决了前三题,最后一题其实也很简单,但是题目没有看清.赛后5min解决了.总体来说,本次周赛是比较简单的一次. 注意点:首先是hard问题的 ...

  10. Codeforce219C-Color Stripe

    E. Color Stripe time limit per test 2 seconds memory limit per test 256 megabytes input standard inp ...