集合继承体系图的理解

  

一、Collection、Collections的区别?

  1. java.util.Collection是一个集合的顶级接口。它提供了对集合对象进行基本操作的通用接口方法。Collection接口在Java类库中有很多具体的实现,其直接继承接口有List与Set。

  2. Collections是集合类的一个工具类,其中提供了一系列静态方法,用于对集合中元素进行排序、搜索以及线程安全等操作。

    1)排序(sort):使用sort方法可以根据元素的自然顺序对指定列表按升序进行排序。列表中的所有元素都必须实现Comparable接口。此列表内的所有元素都必须是使用指定比较器可相互比较的。

 1 List<Integer> list = new ArrayList<Integer>();
 2         int array[] = {112, 111, 23, 456, 231 };
 3         for (int i = 0; i < array.length; i++) {
 4             list.add(array[i]);
 5         }
 6         Collections.sort(list);
 7         for (int i = 0; i < array.length; i++) {
 8             System.out.println(list.get(i));
 9         }
10 结果:23  111  112  231  456

    2)混排(shuffling):混排算法所做的正好与sort相反,它打乱在一个List中可能有的任何排列的踪迹。也就是说,基于随机源的输入重排该list,这样的排列具有相同的可能性(假设随机源是公正的)。这个算法在实现一个碰运气的游戏中是非常有用的。例如,它可被用来混派代表一副牌的card对象的一个list。另外,在生成测试案例时,它也是十分有用的。

    3)反转(reverse):使用reverse方法可以根据元素的自然顺序对指定列表按降序进行排序。Collections.reverse(list)

    4)替换所有的元素(fill):使用指定元素替换指定列表中的所有元素。Collections.fill(li,"aaa");

    5)拷贝(copy):用两个参数,一个目标list和一个源list,将源的元素拷贝到目标,并覆盖它的内容。目标list至少与源一样长。如果它更长,则在目标list中的剩余元素不受影响。

      Collections.copy(list,li):前面一个参数是目标列表,后一个是源列表

    6)返回Collections中的最小元素(min):根据指定比较器产生的顺序,返回给定collection的最小元素。collection中的所有元素都必须是通过指定比较器可相互比较的。

      Collections.min(list)

    7)返回Collections中的最大元素(max):根据指定比较器产生的顺序,返回给顶collection的最大元素。Collections.max(list)

    8)lastIndexOfSubList:返回值定源列表中最后一次出现指定目标列表的起始位置。 int count = Collections.lastIndexOfSubList(list,li);

    9)Rotate:根据指定的距离循环移动指定列表中的元素。  Collections.rotate(list,-1); //如果是负数,则正向移动,正数则反向移动。

二、List、Set的区别?

  List与Set都继承于Collection,Collection是集合的顶级接口;

  List为有序可重复的集合接口,ArrayList、LinkedList、Vector为其实现类;Set是无序不重复的集合接口,HashSet、LinkedHashSet、TreeSet为其实现类。

三、ArrayList、LinkedList、Vector的区别?

  ArrayList、Vector:底层均为数组,查询快、增删慢;ArrayList效率高、是线程不安全的;Vector效率低、线程安全,即某一时刻只有一个线程能够写Vector,避免多线程同时写而引起的不一致性。

  LinkedList:底层为链表结构,查询慢、增删快;

四、HashMap、HashTable

  hashmap的效率高、是线程不安全的,允许键/值为空;

  hashtable是线程安全的,效率低,不允许键/值为空;

五、HashSet

  哈希表存放的是哈希值。hashset存储元素的顺序并不是按照存入时的顺序(和list显然不同)而是按照哈希值来存的所以取数也是按照哈希值取得。元素的哈希值是通过元素的hashcode方法来获取的,hashset首先判断两个元素的哈希值,如果哈希值一样,接着会比较equals方法,如果equals结果为true,hashset就视为同一个元素。如果equals为false就不是同一个元素。

  哈希值相同equals为false的元素是怎么存储呢?就是在同样的哈希值下顺延(可以认为哈希值相同的元素放在一个哈希桶中),也就是哈希一样的存一列。

六、TreeSet

  1. treeset是使用二叉树的原理对add的对象按照指定的顺序排序,每增加一个对象都会进行排序,将对象插入到二叉树指定的位置;

  2. Integer和String对象都可以进行默认的treeset排序,而自定义的对象是不可以的,自己定义的类必须实现Comparable接口,并且覆盖相应的compareTo()函数,才可以正常使用。

  3.在重写compareTo()函数时,要返回相应的值才能使treeset按照一定的规则进行排序。

  4.比较此对象与指定对象顺序,如果该对象小于、等于或大与指定对象,则分别返回负整数、零或正整数。

七、TreeMap(可排序)

  treeMap实现SortedMap接口,能够把它保存的记录根据键排序,默认是按键值的升序排序,也可以指定排序的比较器,当用iterator遍历treeMap时,得到的记录是排过序的。

  如果使用排序的映射,建议使用treeMap。

  在使用treeMap时,key必须实现Comparable接口或在构造treeMap传入自定义的Comparator,否则会在运行时抛出java.lang.ClassCastException类型的异常。

八、LinkedHashMap(记录插入顺序)

  LinkedHashMap是hashMap的一个子类,保存了记录的插入顺序,在用iterator遍历LinkedHashMap时,先得到的记录肯定是先插入的,也可以在构造函数时带参数,按照访问次序排序。

九、Map接口与Collection接口的区别?

  Map是双列的,Collection是单列的;

  Map的键值唯一,Collection的子接口set是唯一的;

  Map的数据结构只针对键有效,Collection针对元素有效;

集合 初始容量 扩容因子 负载因子 底层结构 线程是否安全
ArrayList 10 1.5 无(满了扩容) 数组
Vector 10 2 无(满了扩容) 数组
HashMap 16 2 0.75 数组+链表+红黑树
HashSet 16 2 0.75 数组+链表+红黑树
HashTable 11 2*1+1 0.75 数组+链表

原文地址:https://www.cnblogs.com/HuiH/p/11825006.html

时间: 2024-10-12 15:41:23

集合继承体系图的理解的相关文章

集合的体系图

Collection-->List-->ArrayList -->LinkedList -->Vector -->Set-->HashSet -->TreeSet

跟王老师学异常(三)异常类的继承体系

异常类的继承体系 主讲人:王少华  QQ群号:483773664 学习目标: 1.掌握异常的体系 2.掌握处理异常类的几中常用方法 一.异常类继承体系图 Java提供了丰富的异常类,这些异常类之间有严格的继承关系,如下图所示 从上图可以看出,Java把所有非正常情况分成两种,一种是异常(Exception),另一种是错误(Error),它们都继承Throwable父类. 二.Error Error错误,一般是指虚拟机相关的问题.即仅靠程序本身无法恢复的严重错误.如系统崩溃.虚拟机出错误.动态链接

J2SE知识点归纳笔记(七)---Java IO Part 2:获取键盘输入与IO流体系图

J2SE知识点归纳笔记(七)---Java IO Part 2:获取键盘输入与IO流体系图                                                                 --转载请注明出处:coder-pig 本节引言: 好了,上一节中我们给大家介绍了File与RandomAccessFile类的用法,本节我们还是讲一些 常用的东西,如果学过C++或者C的朋友都知道,获取键盘的输入都很简单,scanf( )和cin就可以 获得我们从控制台输入的参

一、集合框架体系概述

1.为什么出现集合类?• 面向对象语言对事物的体现都是以对象的形式,所以为了方便对多个对象的操作,就对对象进行存储,集合就是存储对象最常用的一种方式.2.数组和集合类同是容器,有何不同?• 数组虽然也可以存储对象,但长度是固定的:集合长度是可变的.数组中可以存储基本数据类型,集合只能存储对象 3.集合类的特点 • 集合只用于存储对象,集合长度是可变的,集合可以存储不同类型 的对象. 4.集合容器因为内部的数据结构不同,有多种具体容器.不断的向上抽取,就形成了集合框架. =============

关于Java中继承和接口的理解

关于Java中继承和接口的理解 Java语言中,为了实现代码重用,设计了继承这一机制,但是,其设计成单继承,这样设计是有原因的,如下图: Figure1:deadly diamond of death 此图问题称为菱形问题(diamond problem),就是说,当A的子类B和C同时实现了A中的方法,则同时继承了B和C的子类D在调用该方法时会出现混乱,无法得知该调用哪一个方法. 既然不能实现多继承,我们就会考虑把很多方法就写在父类里,或者继承抽象类,实现其方法,但是,这样会导致一个问题,比如说

Java 技术体系图

Java 程序员 高级特性 反射.泛型.注释符.自动装箱和拆箱.枚举类.可变 参数.可变返回类型.增强循环.静态导入 核心编程 IO.多线程.实体类. 集合类.正则表达式. XML 和属性文件 图形编程 AWT(Java2D/JavaSound/JMF) .Swing.SWT.JFace 网路编程 Applet.Socket/TCP/UDP.NIO.RMI.CORBA Java 语法基础 类.抽象类.接口.最终类.静态类.匿名类.内部类.异常类.编码规范 Java 开发环境 JDK.JVM.Ec

关于java的this、继承、多态的理解

今天主要学习的内容是关于this.继承.多态的理解,并对其作出总结. 1.This 就目前来说,从个人的实验来看,this主要是对于一个类的对象的引用.它出现的位置主要是以它出现的形式决定的. ①.this(参数类型)这是在在构造方法中调用重写的构造方法. ②.作为某个类的对象来调用类中属性或方法.(用在某个类中的成员方法,因为某个类的对象就可以通过.来调用) 2.extends 继承之前已经了解了一些,接下来就是进一步的总结. ①.protected类型的变量是适合子类和父类之间的使用的,即使

jQuery基本知识体系图

在w3school学习了jQuery,觉得看了一遍,代码敲了一遍,大概的知识点记住了,不过觉得还是把这些知识点,放到一张图上,形成自己的jQuery的知识体系.能做到,一看到jQuery,脑海就浮现jQuery整个的知识体系框架来. jQuery基本知识体系图,布布扣,bubuko.com

一起talk C栗子吧(第一百二十一回:C语言实例--线程知识体系图)

各位看官们,大家好,上一回中咱们说的线程属性的例子,这一回咱们说的例子是:线程知识体系图.闲话休提,言归正转.让我们一起talk C栗子吧! 我们在前面的章回中介绍了与线程相关的知识,在今天的章回中,我们将对这些知识进行总结,并且整理成一张知识体系图,方便大家掌握线程相关的知识. 下面是我们整理的知识体系图,请大家参数: 上图内容中的知识点都有相应的章回对应,下面是我整理的章回对应关系.为了大家方便,我设置了链接,大家可以直接点击链接跳到相应的章回中. 线程概念 线程概念:第一百零七回 线程标识