Java之集合体系

       

目录

Collection集合体系

泛型

Collection集合常用API

遍历集合的方式

 List集合特有方法

ArrayList集合底层原理

LinkedList的特点

 Set系列集合

HashSet底层原理

LinkedHashSet集合概述和特点

TreeSet集合概述和特点

泛型深入

泛型概述

泛型的好处

泛型类的概述

 泛型方法的概述

泛型接口的概述

泛型通配符


        首先要了解为什么需要集合,平常的数组为什么满足不了我们。

        数组在定义完成后,其大小与类型都是确定的。如果我们在数组满了之后继续添加元素,或者在数组中间加入元素,所耗费的代价都是巨大的。因此,集合油然而生,它可以满足前面的一切要求,非常的灵活,同时集合提供的种类和API特别的丰富,因此在开发中被大量使用。

        那么接下来就来看集合的体系结构:

                                                Collection(单列)

集合

                                                 Map(键值)

Collection集合体系

                                                                        ArrayList

                                                List

                                                                        LinkedList

Collection

                                                                        HashSet---------->LinkedHashSet

                                                Set

                                                                        TreeSet

以上为常用的实现类。

List家族:添加的元素都是有序,可重复并且是有索引的

Set家族:添加的元素都是无序,不重复,无索引。

                而LinkedHashSet是有序的,TreeSet:是按照大小默认升序排序的。但都是不重复,无索引。

泛型

        集合一般都是泛型的形式,它可以在编译阶段约束集合只能操作某种数据类型

Collection<String> lists=new ArrayList<String>();

Collection<String> lists=new ArrayList();        //JDK1.7后,后面的泛型可以省略

        注意泛型只支持引用类型的数据,不支持基本类型

Collection<Integer> lists=new ArrayList<Integer>();        //不可以写为int

Collection集合常用API

public boolean add(E e)把给定的对象添加到集合中
public void clear()        清空集合中所有的元素
public boolean remove(E e)       删除给定的元素
public boolean contains(Object obj0判断当前集合是否包含该对象
public boolean isEmpty()判断当前集合是否为空
public int size()返回当前集合里的元素个数
public Object[] to Array()把集合中的元素存储到数组中

遍历集合的方式

1.迭代器遍历

        通过 iterator()方法返回集合中的迭代器对象,且默认索引为集合中的0位置。

        Iterator中常用的方法 有hasNext()来判断当前位置是否有元素存在,next()来获取当前位置的元素,并同时将迭代器对象的索引移向下一个位置。

Iterator<String> it=lists.iterator();
while (it.hasNext()){

    System.out.println(it.next());
}

2.foreach/增强for循环

        增强for循环既可以遍历集合也可以遍历数组

Collection<String> list=new ArrayList<>();

for(String ele:list){

    System.out.println(ele);

}

        修改增强for里面的ele的值改变不会影响集合里的元素

3.Lambda表达式遍历集合

Collection 结合Lambda遍历的API

        default void forEach(Consumer<? super T> action):

Collection<String> lists =new ArrayList<>();
lists.forEach(new Consumer<String>(){

   @Override
    public void accept(String s){
        System.out.println(s); 
    }

});

//可以简化为

lists.forEach(s->{
    System.out.println(s);
});

 List集合特有方法

        因为List集合支持索引,所以多了很多索引操作的独特api,其他Collection的功能List也都继承了。

void add(int index,E element)在此集合中的指定位置插入指定的元素
E remove(int index)删除指定索引处的元素,返回被删除的元素
E set(int index,E element)修改指定索引处的元素,返回被修改的元素
E get(int index)        返回指定索引处的元素

ArrayList集合底层原理

        ArrayList底层是基于数组实现的:根据索引定位元素快,增删需要做元素对的移位操作。

并且在第一次创建集合并添加第一个元素的时候,在底层会创建一个默认长度为10的数组。

如果底层中的数组元素存满了,源码就会创建一个长度为(老数组长度*1.5)长度的新数组。

LinkedList的特点

        底层数据结构是双链表,查询慢,首尾操作的速度是极快的,所以多了很多首尾操作的特有API。

public void addFirst(E e)在该列表开头插入指定的元素
public void addLast(E e)

将指定的元素加到列表的末尾

public E getFirst()返回此列表中的第一个元素
public E getLast()返回此列表中的最后一个元素
public E removeFirst()从此列表中删除并返回第一个元素
public E removeLast()从此列表中删除并返回最后一个元素

 Set系列集合

        首先,Set集合是无序,不重复,且无索引的。因此不可以使用普通的for循环来遍历,也不可以使用索引来获取元素。

        HashSet:无序,不重复,无索引。

        LinkedHashSet:有序,不重复,无索引。

        TreeSet:排序,不重复,无索引。

HashSet底层原理

        HashSet集合底层采取哈希表存储的数据。哈希表是一种对于增删改查数据性能都比较好的结构。在JDK8之前,底层使用数组+链表组成,JDK8之后,底层采用数组+链表+红黑树组成。

LinkedHashSet集合概述和特点

        LinkedHashSet,是有序,不重复,无索引,这里的有序指的是保证存储和取出的元素顺序一致。它的原理和底层数据结构依然是哈希表,,只是每个元素又额外的多了一个双链表的机制记录存储的顺序。

TreeSet集合概述和特点

        TreeSet集合是不重复,无索引,可排序。可排序是按照元素的大小默认升序排序。TreeSet的集合底层是基于红黑树的数据结构实现排序的,增删改查性能都比较好。

        TreeSet集合是一定要排序的,可以将元素按照指定的规则进行排序。

        对于数值类型:Integer,Double,官方默认按照大小升序排序。

        对于字符串类型,默认按照首字符的编号升序排序。

        对于自定义类型,TreeSet无法直接排序。如果要实现排序的话,有两种方式:

        ①让自定义的类实现Comparable接口重写里面的compare to方法来制定比较规则。

        ②TreeSet集合有参数构造器,可以设置Comparator接口对应的比较器对象,来制定规则。

        

泛型深入

泛型概述

        泛型是JDK5中引入的特性,可以在编译阶段约束操作的数据类型,并进行检查

        <数据类型>,泛型只能支持引用数据类型。

        集合体系的全部接口和实现类都是支持泛型的使用

泛型的好处

        它统一数据类型,并且把运行时期额问题提前到了编译期间,避免了强制类型转换可能出现的异常。

泛型类的概述

         定义类时同时定义了泛型的类就是泛型类。

public class MyArrayList<T>{}

//此处泛型变量T可以随便写为任意标识,常见的如E,T,K,V等

//在编译阶段就可以指定数据类型,类似与集合的作用。

 泛型方法的概述

        定义方法时同时定义了泛型的方法就是泛型方法。

public <T> void show(T t) { }

//方法中可以使用泛型接收一切实际类型的参数,方法更具备通用性。

泛型接口的概述

        使用了泛型定义的接口就是泛型接口

public interface Data<E>{}

//泛型接口可以让实现类选择当前功能需要操作的数据类型

泛型通配符

        通配符:?可以在“使用泛型”的时候代表一切类型,E K T V 实在定义泛型的时候使用的

        泛型的上下限:?extends xxx,代表必须是xxx或者是其子类,泛型上限。

                                 ?super xxx,代表必须是xxx或者是其父类,泛型下限。 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

你要不要认识我

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值