Javase之集合体系之(1)集合顶层类Collection与其迭代器知识
集合体系之集合顶层类Collection与其迭代器知识
集合的由来:Java是一门面向对象语言,而面向对象语言对事物的描述是通过对象体现的,为了方便对多个对象进行操作,就必须把多个对象进行存储,而要存储多个对象,就不能是一个基本变量,而应该是一个容器类型的变量,在容器以前的内容中,只有数组和StringBuffer是容器类型。但StringBuffer的结果是一个字符串。故只能使用数组,即对象数组。但对象数组因为长度固定,不能适应变化的需求。所以Java提供集合类。
集合与数组的区别
1.集合的长度可变,而数组长度固定。
2.数组存储了一类元素,集合可以存储不同类型的元素。
3.数组即可存储基本类型数据,又可存储引用类型数据。但集合只能存储引用类型。
Colection(接口)
集合的顶层接口,其子体系有重复的,有唯一的,有无序的,有有序的。
主要子接口有两个:
|–List
有序(存储与取出顺序不一致),可重复。
|–Set
无序(存储顺序与取出顺序不一致,但它有内在的存储顺序该顺序通过哈希表生成,有时在输入时可能与其内在顺序相同,但之并不代表其有序,多输入几个数据就会发现其无序性),唯一。
Collection的功能概述
添加功能
boolean add(E e):添加一个元素
boolean addAll(Collection<? extends E> c):添加一个集合的元素
删除功能
void clear():移除所有元素
boolean remove(Object o):collection 中移除指定元素的单个实例
boolean removeAll(Collection<?> c):移除一个集合的对象(只要有一个被移除就返回true)
判断功能
boolean contains(Object o):判断集合是否包含指定元素
boolean containsAll(Collection<?> c);判断集合是否包含指定的集合元素(包含所有才叫包含)
boolean isEmpty():判断集合是否为空
获取功能
Iterator<E> iterator():生成一个迭代器对象,从而迭代访问每个元素
长度功能
int size():元素个数
交集功能
boolean retainAll(Collection<?> c):删除集合中,在c集合中不存在的元素
解释:假定有A,B两个集合
A,B做交集,最终结果存放在A中,B不变
返回值表示A是否发生变化。
把集合转换为数组
- toArray
Object[] toArray()
Iterator(接口)
对 collection 进行迭代的迭代器。
是遍历集合的一种方式,迭代器依赖于集合存在
迭代器定义为接口的原因:
假定迭代器是一个类,那么我们就可以创建该类对象并调用方法来实现集合的遍历,但是Java中有许多的集合类,而这些集合类的数据结构不同,所以存储和遍历的方式是不同的。进而它们的遍历方式不同,所以没有定义迭代器类。
而无论是哪种集合,都具备获取元素的操作,而且最好在辅助于判断功能,这样在获取前,先判断就不容易出错,所以判断功能和获取功能应该是一个集合遍历所具备的,而每种集合的遍历方式不同。所以就把两种功能提取出来,而不提供具体实现,这就是迭代器声明为接口的原因。
迭代器真正的实现类在具体的子类中,以内部类的方式实现。
因为Collection类实现了Iterable而Iterable中
hasNext
boolean hasNext():如果仍有元素可以迭代,则返回 true。
(换句话说,如果 next 返回了元素而不是抛出异常,则返回 true)。
next
E next():返回迭代的下一个元素。
remove
void remove():从迭代器指向的 collection 中移除迭代器返回的最后一个元素(可选操作)。
每次调用 next 只能调用一次此方法。如果进行迭代时用调用此方法之外的其他方式修改了该迭代器
所指向的 collection,则迭代器的行为是不确定的。
抛出:
UnsupportedOperationException - 如果迭代器不支持 remove 操作。
IllegalStateException - 如果尚未调用 next 方法,或者在上一次调用 next 方法之后已经
调用了 remove 方法。
迭代器使用的两种方式
while
通过迭代器的hasNext()和next()方法实现
import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;
public class t3 {
public static void main(String[] args) {
Collection<String> c = new ArrayList<String>();
c.add("hello");
c.add("world");
c.add("java");
Iterator<String> it = c.iterator();
while (it.hasNext()){
String s = it.next();
System.out.println(s);
}
}
}
out:
hello
world
java
增强for循环
import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;
public class t3 {
public static void main(String[] args) {
Collection<String> c = new ArrayList<String>();
c.add("hello");
c.add("world");
c.add("java");
for (String s:c){
System.out.println(s);
}
}
}
out:
hello
world
java
二者作用相同
Javase之集合体系之(1)集合顶层类Collection与其迭代器知识的更多相关文章
- Javase之集合体系(4)之Map集合
集合体系之Map集合 ##Map<K,V>( 接口 ) 特点:将键映射到值对象,一个映射不能包含重复的键:每个键只能映射一个值 Map集合与Collection集合的区别 Map集合存 ...
- 浅谈Java的集合体系
集合体系框架图 集合接口 Java集合类库将接口(interface)与实现(implementation)分离,如上图,Set是一个集合接口,而HashSet与TreeSet都是实现了Set接口的子 ...
- Java.数据结构.集合体系详解
I. 第一部分:常见数据结构 首先简单说下数据结构. 什么是数据结构?数据结构就是组织数据的方式. 常见的数据结构:栈,堆,树,图,数组,队列,链表. 这里主要介绍与java集合体系相关的栈.数组和链 ...
- Java 集合深入理解(3):Collection
点击查看 Java 集合框架深入理解 系列, - ( ゜- ゜)つロ 乾杯~ 今天心情有点粉,来学学 Collection 吧! 什么是集合? 集合,或者叫容器,是一个包含多个元素的对象: 集合可以对 ...
- Javase之集合体系(3)之Set及其子类知识
集合体系之Set及其子类知识 Set(接口) public interface Set<E>extends Collection<E> 特点:无序(存储顺序与取出顺序不一致 ...
- Javase之集合体系(2)之List及其子类ArrayList,LinkedList与Vector及其迭代器知识
集合体系之List及其子类ArrayList,LinkedList与Vector及其迭代器知识 List(接口) 特点:有序(存储与取出顺序相同),可重复 List子类特点: ArrayList: ...
- javaSE中级篇3——集合体系(另外一种存储容器)——更新完毕
集合还是一种工具,所以它们的包都在java.util包下 1.集合的整个体系结构(是需要掌握的体系,完全体系不是这样) 对图中所说的 序和重复 这两词的说明: 序:指的是添加进去的元素和取出来的元素 ...
- 30.3 Collections 集合体系的工具类
/* * Collections: * 面试题:Collection和Collections有什么区别? * Collection是集合体系的最顶层,包含了集合体系的共性 * Collections是 ...
- JAVA提高九:集合体系
在经过了前面的JDK6.0新特性的学习后,将进一步深入学习JDK,因为集合的重要性,因此从集合开始入手分析: 一.集合概况 Java是一种面向对象语言,如果我们要针对多个对象进行操作,那么首先必要将多 ...
随机推荐
- javaWeb核心技术第八篇之Cookie和Session
会话技术: 会话是什么? 浏览器和服务器交互,浏览器打开网页访问服务器,会话开始,正常交互. 浏览器关闭,会话结束. 会话能干什么? 会话可以共享数据. Cookie和session将数据保存在不同的 ...
- jsb闭包
1.什么是闭包? anw:能够读取其他函数内部变量的函数 本质:将函数内部与函数外部连接起来 2.由于在js中,只有函数内部的子函数才能读取局部变量,因此可以把闭包简单理解成’定义一个在函数内部的函数 ...
- leaflet 结合 d3.js 实现 geojson 数据地形剖面分析(附源码下载)
前言 leaflet 入门开发系列环境知识点了解: leaflet api文档介绍,详细介绍 leaflet 每个类的函数以及属性等等 leaflet 在线例子 leaflet 插件,leaflet ...
- iOS---------开发中 weak和assign的区别
weak和assign的区别-正确使用weak.assign 一.区别 1.修饰变量类型的区别weak只可以修饰对象.如果修饰基本数据类型,编译器会报错-“Property with ‘weak’ a ...
- 【入门级】Docker基础介绍(一)
Docker发展 Docker目前有两个版本: 1.Docker EE:企业版 2.Docker CE:社区版 Open Container Initiative倡议,包含两个规范, 1.运行时规范: ...
- Druid-代码段-5-1
所属文章:池化技术(一)Druid是如何管理数据库连接的? 本代码段对应主流程5,连接的回收: //DruidPooledConnection类的close方法 @Override public vo ...
- mac电脑安装php7
1.安装 homebrew https://www.jianshu.com/p/abea83253671 /usr/bin/ruby -e "$(curl -fsSL https://raw ...
- github.com/pkg/errors库学习
为了理解go error,进一步学习github.com/pkg/errors作的训练. http://www.shtml.net/article/content/tok/48369/id/37733 ...
- Aladdin and the Flying Carpet (LightOJ - 1341)【简单数论】【算术基本定理】【分解质因数】
Aladdin and the Flying Carpet (LightOJ - 1341)[简单数论][算术基本定理][分解质因数](未完成) 标签:入门讲座题解 数论 题目描述 It's said ...
- Noip2017Day2T2 宝藏
题目链接 problem 有\(n\)个点,\(m\)条无向边,选择一个点开始开辟道路.开辟一条长度为\(L\)的链接\(u,v\)的道路会花费\(L \times K\),K表示从选择的最初点到\( ...