博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java知识整理-----集合
阅读量:6223 次
发布时间:2019-06-21

本文共 1840 字,大约阅读时间需要 6 分钟。

Iterator接口:遍历Collection集合中的元素,称为迭代器。

           boolean hasNext();

           Object next();

           void remove();

           用Iterator对集合进行迭代的时候,如果同时又用集合对象的方法操作集合中的元素,会发生ConcurrentModificationException异常,所以在迭代的时候只能用迭代器的方法操作元素,可是Iterator方法有限,只能对元素进行判断,取出和移除操作,如果想要进行其他操作,如添加,修改等就需要使用其子接口:ListIterator.

          |------ListIterator:在Iterator上增加额外方法,支持双向输出

             void set(E);

             void add(E);

             boolean hasPrevious();    返回该迭代器关联集合是否还有上一个元素;

             Object previous();    返回该迭代器的上一个元素;

Collection

           |-----List:元素是有序的,元素可以重复存在,因为该集合体系有索引,判断元素是否相同,依据是元素的equals方法。

                  |------ArrayList:底层的数据结构是数组;特点:查询速度快,增删稍慢;线程不同步

                  |------LinkedList:底层的数据结构是链表;特点:增删速度快,查询稍慢;

                  |------Vector:底层是数组数据结构;线程同步,效率低;被ArrayList替代

                  ArrayList和Vector类都是基于数组实现的List类,Vector比较古老,被ArrayList取代了;ArrayList是线程不安全的,而Vector是线程安全的,但是还是推荐使用ArrayList;

                  获取线程安全的ArrayList对象:Collections类中的方法:static List synchronizedList(List list);返回线程安全的列表。

           |-----Set:元素是无序的(存入和取出的顺序不一定一致),元素不可以重复

                 |------HashSet:底层数据结构是哈希表,线程不同步。

                         HashSet保证元素的唯一性是通过hashCode和equals方法来完成,如果元素的HashCode值相同,会判断equals是否为true,如果元素的HashCode值不同,不会调用                      equals进行比较。

                 |------TreeSet:底层数据结构是二叉树,可以对Set集合中的元素进行排序

                         1、保证元素唯一性的依据是compareTo方法

                         2、排序-----自然排序

                               让元素自身具备比较性,元素需要实现Comparable接口,覆盖compareTo方法

                         3、排序-----比较器排序

                              当元素不具备比较性,或者具备的比较性不是所需要的,这是可以自己定义比较器,实现Comparator接口,覆盖compare方法,然后将比较器对象作为参数传递                            给TreeSet集合的构造函数。

                               

Map

          |------Hashtable:底层是哈希表数据结构,不可以存入null键null值,线程同步,效率低

          |------HashMap:底层是哈希表数据结构,允许使用null键和null值,线程不同步,效率高

          |------TreeMap:底层是二叉树数据结构,线程不同步,可以用于给map集合的键进行排序

          遍历Map集合两种方式:

          Map<Integer,String> m = new HashMap<Integer,String>();

          m.put(1,"A");

          m.put(2,"B");

          m.put(3,"C");

          //第一种方式

          Set s = m.entrySet();

          Iterator it = s.iterator();

          while(it.hasNext()){

                 Map.Entry en = (Entry)it.next();

                 System.out.println(en.getKey()+":"+en.getValue());

          }

        //第二种方式

        s = m.keySet();

        it = s.iterator();

        while(it.hasNext()){

               int i = (int)it.next();

               System.out.println(i+":"+m.get(i));

        }

转载于:https://www.cnblogs.com/ckgame/p/8849681.html

你可能感兴趣的文章
Oracle即将发布的全新Java垃圾收集器 ZGC
查看>>
初识Python
查看>>
shell无限循环
查看>>
推荐.Net、C# 逆向反编译四大工具利器
查看>>
nginx 在ubuntu 上的启动,停止,重启
查看>>
安装xen和虚拟机以及解决其中出现的问题
查看>>
数据库常用授权和授权回收参数配置
查看>>
华为交换机组播配置
查看>>
数通手稿留档——Switch
查看>>
linux命令:kernel内核编译、装载模块管理modprobe/screen
查看>>
定期删除mysql的log文件的脚本
查看>>
Linux主机安全加固
查看>>
30分钟配置好-Puppet: 强大的中心化配置管理系统
查看>>
Oracle 10G R2 RAC 日常管理
查看>>
一些术语
查看>>
梭子鱼宣布新的云融合防火墙功能
查看>>
linux网络相关配置
查看>>
Linux Vim中自动补全Python插件:Pydiction
查看>>
修改IE背景
查看>>
layer弹框
查看>>