1.Java集合概述

  在编程中,常常需要集中存放多个数据。当然我们可以使用数组来保存多个对象。但数组长度不可变化,一旦在初始化时指定了数组长度,则这个数组长度是不可变的,如果需要保存个数变化的数据,数组就显得无能为力了;而且数组无法保存具有映射关系的数据,如成绩表:语文-80,数学-90,这种数据看上去像两个数组,但这两个数组的元素之间有一定的关联关系。

  为了保存数量不确定的数据,以及保存具有映射关系的数据,Java提供了集合类。集合类主要负责保存、盛装其他数据,因此集合类也被称为容器类。所有集合类都位于Java.util包下。

  集合类和数组不一样,数组既可以是基本类型的值,也可以是对象(实际上保存的是对象的引用变量);而集合里只能保存对象,例如不能保存int、只能保存integer。

  Java的集合类主要有两个接口派生而出:Collection和Map,Collection和Map是Java集合框架的根接口,这两个接口又包含了一些子接口和实现类

  如下图所示Collection体系的继承树:

  

  如上图所示显示了Collection体系里的集合,Set、List接口是Collection接口派生的两个子接口,它们分别代表了无序集合、有序集合;Queue是Java提供的队列(队列特点:先进先出)实现,有点类似于List。

  如下图所示Map体系的继承树:

  如上图所示显示了Map接口的众多实现类,这些实现类在功能、用法上存在一定的差异,但他们都有一个功能特征:Map保存的每项数据都是key-value对,也就是由key和value两个值组成。就向前面简绍的成绩单:语文-80,数学-90,每项成绩都是由2个值组成:科目名和成绩;Map里的key是不可重复的,key用于标识集合里每项数据,如果需要查询Map中的数据时,总是根据Map的key来获取。

  根据上两图,我们可以把Java的所有集合分成三大类,其中Set集合类似于一个罐子,把一个对象添加到Set集合时,Set集合无法记住添加这个元素的顺序,所以Set里的元素不能重复(否则系统无法准确识别这个元素);List集合非常像一个数组,它可以记住每次添加元素的顺序,只是List的长度可变。Map集合也像一个罐子,只是它里面的每项数据都由两个值组成。

  如下图所示显示了三种集合的示意图:

  从上图可以看出,如果访问List集合中的元素,可以直接根据元素的索引来访问;如果需要访问Map集合中的元素,可以根据每项元素的key来访问其value;如果希望访问Set集合中的元素,则只能根据元素本身来访问(这也是Set集合里的元素不容许重复的原因)。

  对于Set、List和Map三种集合,最常用的实现类分别为HashSet、ArrayList和HashMap,这三个实现类都没有实现并发控制,是属于线程不安全的

2.Collection和Iterator接口

  • Collection接口

  Collection接口是List、Set和Queue接口的父接口,该接口中定义的方法既可用于操作Set集合,也可用于操作List和Queue集合。Collection中定义了如下操作集合元素的方法:

  1. boolean add(Object o);  该方法用于向集合里添加一个元素。如果集合对象被添加操作改变了则返回true。 
  2. boolean addAll(Collection c);  该方法把集合c里面的所有元素添加到指定集合里。如果集合对象呗添加操作改变了则返回true。
  3. void clear(); 清楚集合里的所有元素,将集合长度变为0。
  4. boolean contains(Object o);  返回集合里是否包含指定元素。
  5. boolean containsAll(Collection c);  返回集合里是否包含集合c里面的所有元素。
  6. boolean isEmpty();   返回集合是否为空。当集合长度为0时,返回true,否则返回false。
  7. Iterator iterator();    返回一个Iterator对象,用于遍历集合里的元素。
  8. boolean remove(Object o);   删除集合中指定元素o,当集合中包含一个或多个元素o时,这些元素将被删除,该方法将返回true。
  9. boolean removeAll(Collection c);  从集合中删除集合c里包含的所有元素(相当于调用该方法的集合减集合c),如果删除了一个或一个以上的元素,该方法返回true。
  10. boolean retainAll(Collection c); 从集合中删除集合c里不包含的所有元素(相当于取得把调用该方法的集合变成该集合和集合c的交集),如果该操作改变了调用该方法的集合,该方法返回true。
  11. int size();   该方法返回集合元素里的个数。
  12. Object[] toArray();  该方法把集合转换成一个数组,所有集合元素变成对应的数组元素。
  • Iterator接口

  Iterator接口也是Java集合框架的成员,但它与Collection系列、Map系列的集合不一样:Collection系列集合、Map系列集合主要用于盛装其他对象,而Iterator则主要用于遍历(即迭代访问)Collection集合中的元素,Iterator对象也被称为迭代器。

  Iterator接口隐藏了各种Collection实现类的底层细节,向应用程序提供了遍历Collection集合元素的统一编程接口,Iterator接口里定义了如下三个方法:

  1. boolean hasNext();   如果被迭代的集合元素还没有被遍历,则返回true。
  2. Object next();    返回集合里下一个元素。
  3. void remove();   删除集合里上一次next返回的元素。
  1. class test{
  2. public static void main(String[] args){
  3. Collection books = new HashSet();
  4. books.add("语文");
  5. books.add("数学");
  6. books.add("英语");
  7. //打印结果为[语文, 英语, 数学]
  8. System.out.println(books);
  9. Iterator it = books.iterator();
  10. while(it.hasNext()){
  11. String book= (String)it.next();
  12. if("语文".equals(book)){
  13. it.remove();
  14. }
  15. //对book变量赋值,不会改变集合元素本身
  16. book = "测试字段";
  17.  
  18. }
  19. //打印结果为[英语, 数学]
  20. System.out.println(books);
  21. }
  22. }

  上面代码对迭代变量book进行赋值,但当我们再次输出books集合时,看到集合里的元素没有任何的改变。这就可以得出一个结论:当使用Iterator对集合元素进行迭代时,Iterator并不是把集合元素本身传给了迭代变量,二是把集合元素的值传给了迭代变量,所以修改迭代变量的值对集合本身没有任何改变。如下原理:

  1. public class test{
  2. public static void main(String[] args){
  3. String str = "zhangsan";
  4. //打印结果为zhangsan
  5. System.out.println(str);
  6. updateString(str);
  7. //打印结果还是zhangsan
  8. System.out.println(str);
  9. }
  10.  
  11. public static void updateString(String str2){
  12. //这个就相当于你在Iterator里面传的值,所以修改变量str2的值对str本身没有任何变化
  13. str2 = "lisi";
  14. }
  15. }

   但是当传递的是对象时,则可以修改传入对象的值如下:

  1. public class test{
  2. public static void main(String[] args){
  3. Person p = new Person();
  4. p.setId(1);
  5. p.setName("zhangsan");
  6. //打印结果为id = 1 name = zhangsan
  7. System.out.println(p);
  8. updatePerson(p);
  9. //打印结果为id = 2 name = lisi
  10. System.out.println(p);
  11.  
  12. }
  13.  
  14. public static void updatePerson(Person p1){
  15. //这个就相当于你在Iterator里面传的是对象,它给你传的是地址,所以你修改p1,就相当于修改了p的值
  16. p1.setId(2);
  17. p1.setName("lisi");
  18. }
  19. }
  20.  
  21. class Person{
  22.  
  23. private Integer id;
  24. private String name;
  25. public Integer getId() {
  26. return id;
  27. }
  28. public void setId(Integer id) {
  29. this.id = id;
  30. }
  31. public String getName() {
  32. return name;
  33. }
  34. public void setName(String name) {
  35. this.name = name;
  36. }
  37.  
  38. @Override
  39. public String toString() {
  40. return "id = " + id + " name = " + name;
  41. }
  42. }

  当使用Iterator来迭代访问Collection集合元素时,Collection集合里的元素不能被改变,只有通过Iterator的remove方法来删除上一次next方法返回的集合元素才可以。否则将会引发Java.util.ConcurrentModificationException异常。如下:

  1. public class Test {
  2.  
  3. public static void main(String[] args){
  4. Collection books = new HashSet();
  5. books.add("语文");
  6. books.add("数学");
  7. books.add("英语");
  8. Iterator it = books.iterator();
  9. while(it.hasNext()){
  10. String book = (String)it.next();
  11. if(book.equals("英语")){
  12. //这样做就会抛Java.util.ConcurrentModificationException
  13. books.remove(book);
  14. }
  15. }
  16. }
  17. }

  • 使用foreach循环遍历集合元素

  除了可以使用Iterator类迭代访问Collection集合里的元素外,也可以使用foreach循环来迭代访问集合元素,而且更加便捷如下:

  1. public class Test {
  2.  
  3. public static void main(String[] args){
  4. Collection books = new HashSet();
  5. books.add("语文");
  6. books.add("数学");
  7. books.add("英语");
  8. for(Object o : books){
  9. String book = (String)o;
  10. if(book.equals("语文")){
  11. //这行代码将会引发java.util.ConcurrentModificationException异常
  12. //books.remove(book);
  13. }
  14. System.out.println(o);
  15. }
  16. }
  17. }

  如上所示,同样,当使用foreach循环迭代访问集合元素时,该集合也不能被改变,否则将引发ConcurrentModificationException异常。

Java集合框架(一)—— Collection、Iterator和Foreach的用法的更多相关文章

  1. Java集合框架之Collection接口

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

  2. Java集合框架(Collection Framework)学习之 Collection与Map概貌

    写过Java的人都知道Java集合类,也用过Java集合类.Java集合类位于 java.util 这个包下,就像它的包名暗示的那样,Java集合类就是一套工具.它就像工匠的工具箱一样,它能给使用它的 ...

  3. java 集合框架(三)Collection

    一.概述 Collection是集合框架的根接口.不同的集合具有不同的特性,比如有的集合可以有重复元素,有的不可以,有的可以排序,有的不可排序,如此等等,而Collection作为集合的根接口,它规范 ...

  4. Java 集合框架之Collection

    此图是 java 中 Collection 相关的接口与类的关系的类图.其中,类只是集合框架的一部分,比较常用的一部分. 第一次画类图,着实很费劲,不过收获也不小. 下面是相关接口和类的解释说明.文字 ...

  5. java集合框架02——Collection架构与源码分析

    Collection是一个接口,它主要的两个分支是List和Set.如下图所示: List和Set都是接口,它们继承与Collection.List是有序的队列,可以用重复的元素:而Set是数学概念中 ...

  6. Java集合框架之接口Iterator

    简述 Iterator迭代器的定义:迭代器(Iterator)模式,又叫做游标(Cursor)模式.GOF给出的定义是,提供一种方法访问一个容器(container)对象中各个元素,而又不需暴露该对象 ...

  7. Java集合框架(Collection Framework)学习之 HashMap

    从API文档可以得到HashMap的以下几个特点: 基于哈希表(hash table)实现,并且是链式哈希表 允许空值和空键(null=null 键值对) HashMap与Hashtable基本相同, ...

  8. java集合框架之Collection

    参考http://how2j.cn/k/collection/collection-collection/366.html Collection是 Set List Queue和 Deque的接口Qu ...

  9. java集合框架中contains(),containsKey()和containsValue()的用法:

    List集合的contains()方法用于判断集合中包不包含某个元素,返回值是boolean. Map集合的containsKey()和containsValue()方法和上面的相同. 示例: pub ...

  10. Java学习--java中的集合框架、Collection接口、list接口

    与数组相比:1.数组的长度固定,而集合的长度可变2.数组只能通过下表访问元素,类型固定,而有的集合可以通过任意类型查找所映射的具体对象 java集合框架:collection(list序列,queue ...

随机推荐

  1. <script>元素在XHTML中的用法

    编写XHTML代码的规则要比编写HTML严格得多,例如如下代码: <script type="text/javascript"> function compare(a, ...

  2. junit4X系列--Statement

    原文出处:http://www.blogjava.net/DLevin/archive/2012/05/11/377954.html.感谢作者的无私分享. 初次用文字的方式记录读源码的过程,不知道怎么 ...

  3. Linux指令--ps

    Linux中的ps命令是Process Status的缩写.ps命令用来列出系统中当前运行的那些进程.ps命令列出的是当前那些进程的快照,就是执行ps命令的那个时刻的那些进程,如果想要动态的显示进程信 ...

  4. PHP获取客户端和服务器端IP(转)

    客户端的ip变量: $_SERVER['REMOTE_ADDR'] :客户端IP,也有可能是代理IP $_SERVER['HTTP_CLIENT_IP']:代理端的IP,可能存在,也可能伪造 $_SE ...

  5. CentOS修改Tomcat端口号

    Linux下修改Tomcat默认端口 1.方法一 假设tomcat所在目录为/usr/local/apache-tomcat/ 1.打开tomcat配置文件 # vi /usr/local/apach ...

  6. Node.js:上传文件,服务端如何获取文件上传进度

    内容概述 multer是常用的Express文件上传中间件.服务端如何获取文件上传的进度,是使用的过程中,很常见的一个问题.在SF上也有同学问了类似问题<nodejs multer有没有查看文件 ...

  7. 对List中每个对象元素按时间顺序排序

    需求: 需要对List中的每个User按照birthday顺序排序,时间由小到大排列. 代码实现: import java.text.SimpleDateFormat; import java.uti ...

  8. ABP官方文档翻译 6.6 Javascript API

    JavaScript API AJAX 通知 消息 UI Block和Busy 事件总线 日志 其他实用功能 ABP提供了一套对象和函数,用来简化.标准化javascript的开发. 这里是ABP提供 ...

  9. 再看Java基本类型

    Java中的基本类型可以分为三类,字符类型char,布尔类型boolean以及数值类型byte.short.int.long.float.double. 数值类型又可以分为整数类型byte.short ...

  10. HDU 3374 String Problem

    最大最小表示法与KMP求循环节 最大最小表示法 最大最小表示法与KMP求循环节的模板题, #include <iostream> #include <cstdio> #incl ...