Collection接口常用的子接口有:List接口、Set接口
List接口常用的子类有:ArrayList类、LinkedList类
Set接口常用的子类有:HashSet类、LinkedHashSet类

方式1:Collection<元素类型> 变量名 = new ArrayList<元素类型>();
方式2:Collection 变量名 = new ArrayList();
方式1创建的集合,只能存储<>中指定的元素类型,该方式为常用方式
方式2创建的集合,集合的元素类型默认为Object类型,即任何类型的元素都可以存储。

Collectoin集合的功能概述:

      1)添加功能

          boolean add(Object obj):添加功能

          boolean addAll(Collection c):添加一个集合的元素

      2)删除功能

          void clear():移除所有元素

          boolean remove(Object obj):移除一个元素

          boolean removeAll(Collection c):移除一个集合的元素(只要有一个元素移除

了就返回true)

      3)判断功能

          boolean contains(Object obj):判断集合中是否包含指定的元素

          boolean containsAll(Collection c):判断集合中是否包含指定的集合元素(只

有包含指定集合中所有的元素才叫包含)

          boolean isEmpty():判断集合是否为空(指集合的数据元素为空)

      4)获取功能

          Iterator iterator():迭代器,集合专有的遍历方式

      5)长度功能

          int size():元素的个数

      6)交集功能

          boolean retainAll(Collection c):两个集合中都有的元素(假设有两个集合A、

B,A对B做交集,最终的结果保存在集合A中,集合B不变,返回值表示的是集合A是否发生过改变)

      7)把集合转换为数组

          Object[] toArray():把集合转成数组,可以实现集合的遍历

  Collection集合有两个子接口List和Set。

List集合

List集合的特点:有序(指存储和取出元素的顺序一致)、存储元素可重复

    List集合的特有功能:

      1)添加功能

        void add(int index,Object element):在指定位置添加元素

      2)获取功能

        Object get(int index):获取指定位置的元素

      3)列表迭代器

        ListIterator listIterator():迭代所有的元素

        ListIteraror listIterator(int index):从指定位置开始迭代元素

      4)删除功能

        Object remove(int index):根据索引删除元素,返回被删除的元素

      5)修改功能

        Object set(int index,Object element):根据索引修改元素,返回被修改的元素

   List集合有ArrayList、Vector和LinkedList三个常用子类。

LinkedList 中的方法

Set集合

    Set集合的特点:无序(指元素的存储和取出顺序不一致)、存储元素唯一

    Set集合有HashSet和TreeSet两个常用子类。

Set集合的子类

    1)HashSet类的特点:

      HashSet类不保证Set的迭代顺序,特别是它不保证该顺序恒久不变。

      注意:虽然Set集合的元素是无序的,但是作为集合来说,它肯定有它自己的元素存储顺序

。而如果你的顺序恰好和它的存储顺序一致,这代表不了有序,你可以多存储一些数据,看效果。

    HashSet类的底层数据结构是哈希表。而哈希表保证元素的唯一性依赖于两个方法:int

hashCode()和boolean equals(Object obj)

    用HashSet存储元素的执行顺序:

      首先比较hashCode()值是否相同

        是:继续执行equals(),看其返回值

            是true:说明元素重复,不添加

            是false:就直接添加到集合

        否:就直接添加到集合

    HashSet类有一个子类LinkedHashSet,LinkedHashSet存储元素的特点是有序、唯一

      LinkedHashSet的底层数据结构由链表和哈希表组成,由链表保证元素有序,由哈希表保证

元素唯一。

---|Collection: 单列集合  
            ---|List: 有存储顺序, 可重复  
                ---|ArrayList:  数组实现, 查找快, 增删慢  
                            由于是数组实现, 在增和删的时候会牵扯到数组  
                                                增容, 以及拷贝元素. 所以慢。数组是可以直接  
                                                按索引查找, 所以查找时较快  
                ---|LinkedList: 链表实现, 增删快, 查找慢  
                            由于链表实现, 增加时只要让前一个元素记住自  
                                               己就可以, 删除时让前一个元素记住后一个元  
                                               素, 后一个元素记住前一个元素. 这样的增删效  
                                             率较高但查询时需要一个一个的遍历, 所以效率  
                                                较低  
                ---|Vector: 和ArrayList原理相同, 但线程安全, 效率略低  
                             和ArrayList实现方式相同, 但考虑了线程安全问  
                                                题, 所以效率略低  
            ---|Set: 无存储顺序, 不可重复  
                ---|HashSet  
                ---|TreeSet  
                ---|LinkedHashSet    
---| Map: 键值对  
        ---|HashMap  key不可重复,无序存取,哈希表实现
        ---|TreeMap  
        ---|HashTable  
        ---|LinkedHashMap  双向链表的哈希表

LinkedList

Collection接口和list,set子类的更多相关文章

  1. 集合中Set接口与Collection接口,常用子类TreeSet,HashSet.

    Set接口与List接口的不同之处在于: 不允许有重复的数据. 定义如下: public interface Set<E>extends Collection<E> 主要方法与 ...

  2. java中常用的数据结构--Collection接口及其子类

    java中有几种常用的数据结构,主要分为Collection和map两个主要接口(接口只提供方法,并不提供实现),而程序中最终使用的数据结构是继承自这些接口的数据结构类. 一.集合和数组的区别 二.C ...

  3. Collection接口

    Collection接口所定义的方法: clear:清空 retainAll 求一个Collection和另一个 Collection的交集. object[] toArray()  把里面的各个对象 ...

  4. Java集合框架之Collection接口

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

  5. 集合框架之Collection接口

    Collection 层次结构中的根接口.Collection表示一组对象,这些对象也称为 collection 的元素.一些 collection 允许有重复的元素,而另一些则不允许.一些 coll ...

  6. java_18 Collection接口

    1.Collection接口 Collection 层次结构 中的根接口.Collection 表示一组对象,这些对象也称为 collection 的元素.一些 collection 允许有重复的元素 ...

  7. JAVA中Collection接口和Map接口的主要实现类

    Collection接口 Collection是最基本的集合接口,一个Collection代表一组Object,即Collection的元素(Elements).一些Collection允许相同的元素 ...

  8. Java:集合,Collection接口框架图

    Java集合大致可分为Set.List和Map三种体系,其中Set代表无序.不可重复的集合:List代表有序.重复的集合:而Map则代表具有映射关系的集合.Java 5之后,增加了Queue体系集合, ...

  9. 【Java面试题】35 List, Set, Map是否继承自Collection接口?

    Collection是最基本的集合接口,声明了适用于JAVA集合(只包括Set和List)的通用方法. Set 和List 都继承了Conllection:Set具有与Collection完全一样的接 ...

随机推荐

  1. Netty(一):ByteBuf读写过程图解

    我们知道ByteBuf通过读写两个索引分离,避免了NIO中ByteBuffer中读写模式切换时,需要flip等繁琐的操作. 今天就通过一段测试代码以及图例来直观的了解下ByteBuf中的readInd ...

  2. 使用JXL.jar实现JAVA对EXCEL的读写操作

    简介: jxl.jar是通过java操作excel表格的工具类库 jxl操作excel包括对象Workbook(工作簿),Sheet(工作表) ,Cell(单元格). 一个excel就对应一个Work ...

  3. CF思维联系–CodeForces - 225C. Barcode(二路动态规划)

    ACM思维题训练集合 Desciption You've got an n × m pixel picture. Each pixel can be white or black. Your task ...

  4. USACO Training Section 1.1 坏掉的项链Broken Necklace

    题目描述 你有一条由N个红色的,白色的,或蓝色的珠子组成的项链(3<=N<=350),珠子是随意安排的. 这里是 n=29 的二个例子: 第一和第二个珠子在图片中已经被作记号. 图片 A ...

  5. python(logging 模块)

    1.logging 模块的日志级别 DEBUG:最详细的日志信息,典型应用场景是 问题诊断 INFO:信息详细程度仅次于DEBUG,通常只记录关键节点信息,用于确认一切都是按照我们预期的那样进行工作 ...

  6. Fiddler 介绍

    1.fiddler原理介绍 fiddler 是一个抓包工具,当浏览器访问服务器会形成一个请求,此时,fiddler就处于请求之间,当浏览器发送请求,会先经过 fiddler,然后在到服务器:当服务器有 ...

  7. Linux安装maven(详细教程)

    一.简介 Maven是意第绪语,意思是“知识的积累者”,最初是为了简化Jakarta Turbine项目中的构建过程.有几个项目,每个项目都有自己的Ant构建文件,所有项目都略有不同.JAR已检入CV ...

  8. 题解 CF545A 【Toy Cars】

    题目传送门 太弱了,只能写写A题的题解 题意 给你一个 $n·n$ 的矩阵,翻车分三种情况: 如果 $a_i,_j=1$ ,记录第 $i$ 辆车 如果 $a_i,_j=2$ ,记录第 $j$ 辆车 如 ...

  9. 在linux上搭建nacos集群(步骤详细,linux小白也搞得定)

    (1)nacos官网:https://github.com/alibaba/nacos/releases/tag/1.2.1下载nacos安装包到window本地(后缀为tar.zip) (2)在li ...

  10. 清北学堂—2020.3NOIP数学精讲营—Day 1 morning 重点笔记

    qbxt Day 1 morning 重点笔记 --2020.3.8 济南 主讲:钟皓曦 1 正数%负数==正数 负数%正数==负数 负数%负数==负数 a%b的答案的符号取决于a的符号. 2 快速幂 ...