Day 4:集合——迭代器与List接口
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接口的更多相关文章
- 集合迭代器快速失败行为及CopyOnWriteArrayList
以下内容基于jdk1.7.0_79源码: 什么是集合迭代器快速失败行为 以ArrayList为例,在多线程并发情况下,如果有一个线程在修改ArrayList集合的结构(插入.移除...),而另一个线程 ...
- Java集合框架之Collection接口
Java是一门面向对象的语言,那么我们写程序的时候最经常操作的便是对象了,为此,Java提供了一些专门用来处理对象的类库,这些类库的集合我们称之为集合框架.Java集合工具包位于Java.util包下 ...
- java 集合框架(二)Iterable接口
Iterable接口是java 集合框架的顶级接口,实现此接口使集合对象可以通过迭代器遍历自身元素,我们可以看下它的成员方法 修饰符和返回值 方法名 描述 Iterator<T> iter ...
- Java集合框架之四大接口、常用实现类
Java集合框架 <Java集合框架的四大接口> Collection:存储无序的.不唯一的数据:其下有List和Set两大接口. List:存储有序的.不唯一的数据: Set:存储无序的 ...
- 集合框架之List接口
有序的 collection(也称为序列).此接口的用户可以对列表中每个元素的插入位置进行精确地控制.用户可以根据元素的整数索引(在列表中的位置)访问元素,并搜索列表中的元素. 与 set 不同,列表 ...
- -1-3 java集合框架基础 java集合体系结构 Collection 常用java集合框架 如何选择集合 迭代器 泛型 通配符概念 Properties 集合 迭代器
集合又称之为容器存储对象的一种方式 •数组虽然也可以存储对象,但长度是固定的:显然需要可变长度的容器 集合和数组的区别? A:长度区别 ...
- Java精选笔记_集合【List(列表)接口】
List(列表)接口 简介 List接口继承自Collection接口,是单列集合的一个重要分支,习惯性地会将实现了List接口的对象称为List集合. 元素是有序的,即元素的存入顺序和取出顺序一致, ...
- Java集合----概述、Collection接口、Iterator接口
Java 集合概述 Java 集合就像一种容器,可以把多个对象的引用放入容器中. Java 集合类可以用于存储数量不等的多个对象,还可用于保存具有映射关系的关联数组 Java 集合可分为 Set.Li ...
- Java集合框架之Set接口浅析
Java集合框架之Set接口浅析 一.java.util.Set接口综述: 这里只对Set接口做一简单综述,其具体实现类的分析,朋友们可关注我后续的博文 1.1Set接口简介 java.util.se ...
随机推荐
- 连接数据库 - (mysql-thinkphp) (2)
1.现在conf里面写好选择的数据库 选择好了以后 2.在index里面输入 查询mysql数据库里面的表tables_priv的所有数据 public function index() { $res ...
- ESX/ESXi 主机上的每个插槽中安装了多少内存
要确定在 ESX/ESXi 主机上的每个插槽中安装了多少内存,请执行以下操作: 1. 启动ssh服务 2. 登陆esxi主机查看 使用 SSH 客户端登录主机,以 root 用户身份运行以下命令之一: ...
- java虚拟机05(Java虚拟机的参数)
原文在此 (1)-Xms20M 表示设置堆容量的最小值为20M,必须以M为单位 (2)-Xmx20M 表示设置堆容量的最大值为20M,必须以M为单位.将-Xmx和-Xms设置为一样可以避免堆自动扩展. ...
- H5易企秀
周末被领导叫回来加班,说要做一个易企秀一样的页面,然后就有这篇笔记 原计划用几百个计时器去执行,后面放弃了,太难改了,还是选择了animate.css插件,这是一个纯css的插件,只需要引入css就行 ...
- linux 下office软件推荐
概述 最近想使用LINUX下搭建服务器,所以查找一些需要用的软件. linux下最好的office解决办法 其实因为我是不怎么使用office的,我也不知道不同office有什么不一样,直到有一次写奖 ...
- 整理jvm概念和原理详解以及gc机制
注:源代码就是.java文件,JVM字节码就是.class文件 1. Java 堆(Java Heap):(1)是Java虚拟机所管理的内存中最大的一块.(2)在虚拟机启动的时候创建.堆是jvm所有线 ...
- java格式化代码(java格式化代码工具类)
下别人的原来链接..... 支持效果不好要想格式化好需要解析语法树 7个积分我这里免费下 转自 https://download.csdn.net/download/jkl012789/ ...
- C# 绘制矩形方框读写内存类 cs1.6人物透视例子
封装的有问题 其中方框可能在别的方向可能 会显示不出来建议不要下载了 抽时间我会用纯c#写一个例子的 其中绘制方框文字和直线调用的外部dll采用DX11(不吃CUP)绘制我封装成了DLL命名为 S ...
- <深入理解redis>读书笔记
chapter2 键管理与数据结构 对大多数redis解决方案而言,键的命名设计至关重要.对于管理来说,内存消耗和redis性能都与数据结构设计相关.所以对开发者而言,最好有数据结构的命名文档规范. ...
- 《ES6标准入门》(阮一峰)--7.数值的扩展
1.二进制和八进制表示法 ES6 提供了二进制和八进制数值的新的写法,分别用前缀0b(或0B)和0o(或0O)表示. 0b111110111 === 503 // true 0o767 === 503 ...