Collection-迭代方法

1、toArray()  返回Object类型数据,接收也需要Object对象! Object[] toArray();

  Collection c = new ArrayList();

  Object[] arr = c.toArray();

2、iterator()  Collection的方法,返回实现Iterator接口的对象,一般用Iterator接口类型数据接收,体现程序的多态性,是程序灵活的表现

迭代器的作用:就是用于抓取集合中的元素。

迭代器的方法:
            hasNext()   问是否有元素可遍历。如果有元素可以遍历,返回true,否则返回false 。
            next()         获取元素
            remove()    移除迭代器最后一次返回 的元素。

NoSuchElementException 没有元素的异常。
出现的原因: 没有元素可以被迭代(抓取)了

import java.util.*;
public class Demo1 { public static void main(String[] args) {
Collection c = new ArrayList();
Collection r = new ArrayList();
c.add("李杰");
c.add("李英");
c.add("李汉斯");
c.add("李汉三");
c.add("狗蛋"); Iterator b = c.iterator();
Iterator h = r.iterator();
//返回一个迭代器
//疑问:iterator()方法返回的是一个接口类型,为什么接口又可以调用方法可以使用呢?
//iterator 实际 上返回的是iterator接口的实现类对象。
System.out.println(b.hasNext());
System.out.println(h.hasNext()); b.next();
b.next();
b.remove(); //删除迭代器最后一次返回的元素。 /*while(b.hasNext()){ // hasNext() 问是否有元素可以遍历。
System.out.println("元素:"+ b.next()); //获取元素
}*/
/*清空集合 的元素
while(b.hasNext()){
b.next();
b.remove();
}*/
System.out.println("集合的元素:"+ c);
}
}

因为迭代器不会返回元素,所以remove();方法不会主动移除集合中数据,需要配合next()使用。及删除的是next()最后一次抓取的数据

遍历集合的方法
1、
Object[] arr = c.toArray(); // toArray()  把集合 的元素存储到一个 Object的数组中 返回。
for(int i = 0 ; i<arr.length ; i++){
 System.out.print(arr[i]+",");
}
2、使用hasNext()    next()组合方法便利

while(it.hasNext()){

    User user = (User) it.next();

    if(user.account==id&&user.password.equals(password)){

    isLogin = true;

     }

}

3、

使用get方法遍历集合的元素:
  for (int i = 0; i < list.size() ; i++) {
   System.out.print(list.get(i)+",");
  }

集合的体系:

 Collection 单列集合 的根接口

     List  如果是实现了List接口的集合类,该集合类具备的特点:有序,可重复

    Set   如果是实现了Set接口的集合类,该集合类具备的特点: 无序,不可重复

List接口

有序: 集合的有序不是指自然顺序,而是指添加进去的顺序与元素出来的顺序是一致的

List接口中特有的方法具备的特点: 操作的方法都存在索引值。 
只有List接口下面的集合类才具备索引值。其他接口下面的集合类都没有索引值。

List接口中特有方法:    

添加

    add(int index, E element)
    addAll(int index, Collection<? extends E> c)
获取:
    get(int index)
    indexOf(Object o)
    lastIndexOf(Object o)
    subList(int fromIndex, int toIndex)
修改:
    set(int index, E element)

迭代

    listIterator()

import java.util.*;public class Demo2 {

    public static void main(String[] args) {
List list= new ArrayList();
list.add("李杰");
list.add("李英");
list.add("李汉三");
list.add("李汉斯"); /*
//添加方法
list.add(2, "李四");
List list2 = new ArrayList();
list2.add("张三");
list2.add("王二");
list.addAll(2,list2);
*/ /*
//获取的方法
System.out.println(list.get(1)); //根据索引值获取集合中的元素
使用get方法遍历集合的元素:
for (int i = 0; i < list.size() ; i++) {//判断集合长度用size()
System.out.print(list.get(i)+",");
} System.out.println(list.indexOf("李杰"));//找出指定元素第一次出现在集合中 的索引值
System.out.println(list.lastIndexOf("李汉斯"));//找指定的元素最后一次出现在集合中的索引值
List subList = list.subList(1, 3); //指定开始与结束的索引值截取集合中的元素。
System.out.println(subList)//返回值是一个List输出子集合的元素
*/
list.set(3, "李白"); //使用指定的元素替换指定索引值位置的元素。 System.out.println(list);//输出集合的元素,查看效果
}
}

ListIterator接口特有的方法:
 
 添加:
    hasPrevious()  判断是否存在上一个元素
    previous()    当前指针先向上移动一个单位,然后再取出当前指针指向的元素
    next();  先取出当前指针指向的元素,然后指针向下移动一个单位
    add(E e)   把当前有元素插入到当前指针指向的位置上
    set(E e)   替换迭代器最后一次返回的元素

import java.util.*;

public class Demo3 {

    public static void main(String[] args) {
List list = new ArrayList();
list.add("李杰");
list.add("李英");
list.add("李汉三");
list.add("李汉斯"); ListIterator it = list.listIterator(); //返回的是一个List接口中特有的迭代器
/*System.out.println(it.hasPrevious())//判断是否有上一个元素,有true,没有false
System.out.println(it.previous());//获取上一个元素
it.next();
System.out.println(it.previous());//获取上一个元素 while(it.hasNext()){
it.next();
} while(it.hasPrevious()){
System.out.println("元素:"+ it.previous());
} it.next();
it.next();
it.add("李白");
*/
it.next();
it.next();
it.set("李白"); System.out.println("集合的元素:"+ list);
}
}

作业: 使用三种方式遍历集合的元素.  
  一、 使用get方法遍历。
  二、 使用迭代器正序遍历。
  三、 使用迭代器逆序遍历。

import java.util.*;
public class Demo4 { public static void main(String[] args) {
List list = new ArrayList();
list.add("李杰");
list.add("李英");
list.add("李汉三"); for(int i = 0 ; i<list.size() ; i++){
System.out.print(list.get(i)+",");
}
System.out.println();
ListIterator it = list.listIterator();
while(it.hasNext()){
System.out.print(it.next()+",");
}
System.out.println();
while(it.hasPrevious()){
System.out.print(it.previous()+",");
}
}
}

Day 4:集合——迭代器与List接口的更多相关文章

  1. 集合迭代器快速失败行为及CopyOnWriteArrayList

    以下内容基于jdk1.7.0_79源码: 什么是集合迭代器快速失败行为 以ArrayList为例,在多线程并发情况下,如果有一个线程在修改ArrayList集合的结构(插入.移除...),而另一个线程 ...

  2. Java集合框架之Collection接口

    Java是一门面向对象的语言,那么我们写程序的时候最经常操作的便是对象了,为此,Java提供了一些专门用来处理对象的类库,这些类库的集合我们称之为集合框架.Java集合工具包位于Java.util包下 ...

  3. java 集合框架(二)Iterable接口

    Iterable接口是java 集合框架的顶级接口,实现此接口使集合对象可以通过迭代器遍历自身元素,我们可以看下它的成员方法 修饰符和返回值 方法名 描述 Iterator<T> iter ...

  4. Java集合框架之四大接口、常用实现类

    Java集合框架 <Java集合框架的四大接口> Collection:存储无序的.不唯一的数据:其下有List和Set两大接口. List:存储有序的.不唯一的数据: Set:存储无序的 ...

  5. 集合框架之List接口

    有序的 collection(也称为序列).此接口的用户可以对列表中每个元素的插入位置进行精确地控制.用户可以根据元素的整数索引(在列表中的位置)访问元素,并搜索列表中的元素. 与 set 不同,列表 ...

  6. -1-3 java集合框架基础 java集合体系结构 Collection 常用java集合框架 如何选择集合 迭代器 泛型 通配符概念 Properties 集合 迭代器

    集合又称之为容器存储对象的一种方式 •数组虽然也可以存储对象,但长度是固定的:显然需要可变长度的容器 集合和数组的区别?                 A:长度区别                  ...

  7. Java精选笔记_集合【List(列表)接口】

    List(列表)接口 简介 List接口继承自Collection接口,是单列集合的一个重要分支,习惯性地会将实现了List接口的对象称为List集合. 元素是有序的,即元素的存入顺序和取出顺序一致, ...

  8. Java集合----概述、Collection接口、Iterator接口

    Java 集合概述 Java 集合就像一种容器,可以把多个对象的引用放入容器中. Java 集合类可以用于存储数量不等的多个对象,还可用于保存具有映射关系的关联数组 Java 集合可分为 Set.Li ...

  9. Java集合框架之Set接口浅析

    Java集合框架之Set接口浅析 一.java.util.Set接口综述: 这里只对Set接口做一简单综述,其具体实现类的分析,朋友们可关注我后续的博文 1.1Set接口简介 java.util.se ...

随机推荐

  1. 蓝桥杯 2n皇后问题

    题意: 问题描述 给定一个n*n的棋盘,棋盘中有一些位置不能放皇后.现在要向棋盘中放入n个黑皇后和n个白皇后,使任意的两个黑皇后都不在同一行.同一列或同一条对角线上,任意的两个白皇后都不在同一行.同一 ...

  2. 使用PYaudio录制音频和视频(自己)

    参考:https://blog.csdn.net/zhaoyun_zzz/article/details/84341801 音频录制:简洁版 import pyaudioimport waveimpo ...

  3. springCloud 之 Eureka注册中心高可用配置

    springCloud的eureka高可用配置方案思路是:几个服务中心之间相互注册,比如两个注册中心,A注册到B上,B注册到A上,如果是三个注册中心则是:A注册到BC上,B注册到AC上,C注册到AB上 ...

  4. Day5-T3

    原题目 要开运动会了,神犇学校的n个班级要选班服,班服共有100种样式,编号1~100.现在每个班都挑出了一些样式待选,每个班最多有100个待选的样式.要求每个班最终选定一种样式作为班服,且该班的样式 ...

  5. WAFの基本防护透明流模式v1.0

                      一.WAFの透明流模式     1)首先先配置WAF的网络,配置一个网桥接口,设置IP便于带内管理.             2)当然,如果需要不同网段之间都能够管 ...

  6. Run K8s / 安装指南

    Windows 下载 kubectl 官方文档下载对应操作系统的 Kubectl 下载 minikube 如图将下载的文件放在一起,如图:   配置环境变量,如图:   配置Hype-V或者安装Vir ...

  7. YOKOGAWA ProSafe-RS 通道测试 CENTUMVP

    20180927 我并没有调试这个项目 仅仅是听同事讲解了 横河ProSafe-RS通道测试 然后做了笔记 软件安装并不在本记录中 ProSafe-RS版本 CENTUMVP版本 ProSafe-RS ...

  8. git克隆项目后的操作

    使用https路径clone代码后,如果直接提交,会出现两个问题: 1. 提交的用户是操作系统登陆用户: 2. 需要重复输入用户名和密码: 一 设置用户名和邮箱 git config user.nam ...

  9. 【剑指Offer】面试题28. 对称的二叉树

    题目 请实现一个函数,用来判断一棵二叉树是不是对称的.如果一棵二叉树和它的镜像一样,那么它是对称的. 例如,二叉树 [1,2,2,3,4,4,3] 是对称的.     1    / \   2   2 ...

  10. JVM--a == (a = b)基于栈的解释器执行过程

    前言 在翻阅ConcurrentLinkedQueue的代码的时候,发现这样一段代码在JDK源码中总是出现. t != (t = tail) 原先总是以为这不就是 t != t ?很是纳闷,遂Demo ...