集合

集合框架

一、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. openstack的yum源出错,配置openstack-ocata版的在线yum源,openstack的yum源配置

    真的是几经周折,终于配置好了!我做好了一键配置yum的代码,地址:https://www.cnblogs.com/guarding/p/12321702.html 首先看一下配置前的报错信息把: 需要 ...

  2. Java 基础(四):数组

    数组,一种应用非常广泛的数据结构,简单地来说就是一组类型相同且无序的元素的存储在固定长度且有序的内存空间. 创建一个数组 在Java中,我们可以通过[]去声明一个指定类型的数组 int[] a; // ...

  3. forEach 循环数组 # for in 循环对象 key # for of 循环对象 value

    forEach 循环数组 # for in 循环对象 key # for of 循环对象 value

  4. Java并发编程学习前期知识下篇

    Java并发编程学习前期知识下篇 通过上一篇<Java并发编程学习前期知识上篇>我们知道了在Java并发中的可见性是什么?volatile的定义以及JMM的定义.我们先来看看几个大厂真实的 ...

  5. 一文带你熟悉SpringIOC

    Spring的IOC: IOC是Spring的一个核心组件,理解IOC是迈向Spring大门的重要一步 现实生活中,我们写字用的笔会有多种颜色,为了做不同的标记,需要用不同颜色的笔.如果只是使用一两种 ...

  6. Natas13 Writeup(文件上传,绕过图片签名检测)

    Natas13: 与上一关页面类似,还是文件上传,只是多了提示“出于安全原因,我们现在仅接受图像文件!”.源码如下 function genRandomString() { $length = 10; ...

  7. 10. webdriver调用javascript

    webdriver提供了操作浏览器的前进和后退的方法,但是对于浏览器公东条并没有提供相应的操作方法.于是就需要借助JavaScript来控制浏览器的滚动条.webdriver提供了execute_sr ...

  8. WEB应用之httpd基础入门(二)

    前文我们聊了下httpd的一些基础设置,聊了下httpd的配置文件格式,长连接.mpm的配置以及访问控制基于文件路径和URL管控,回顾请参考https://www.cnblogs.com/qiuhom ...

  9. 【转载】oracle的安装和配置

    转自: https://blog.csdn.net/weixin_40364885/article/details/80787472 一.概念 oracle在使用的时候时是不收费的,如果你要在工作中来 ...

  10. HDOJ 1301最小生成树的Kruskal算法

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1301 将结点的字符信息处理成点信息即可,代码如下: #include<bits/stdc++.h ...