欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Java集合Collention

程序员文章站 2022-11-09 11:49:57
集合:又被称为容器,用来存储数据,他是一个对象,能够将具有相同性质的多个元素汇聚成一个整体,集合被用于存储,获取,操纵和传输聚合的数据。 这种数据结构称为集合 Collenction:他是集合的根接口,定义了所有集合的相关功能方法。 数组和集合的区别: 数组 集合 存数据 存数据 存同一种数据类型的 ......
  • 集合:又被称为容器,用来存储数据,他是一个对象,能够将具有相同性质的多个元素汇聚成一个整体,集合被用于存储,获取,操纵和传输聚合的数据。

  • 这种数据结构称为集合 collenction:他是集合的根接口,定义了所有集合的相关功能方法。

  • 数组和集合的区别:

  •  

    数组

    集合

    存数据

    存数据

    存同一种数据类型的数据

    存任意数据类型

    数组中没有方法

    集合中提供了很多方法供我们操作

    存储基本数据类型和引用数据类型string

    存储引用数据类型(对象)

    • arraylist:是接口list的常用实现类,arraylist的底层是以数组实现的,且数组容量可变(初始容量是10,存多于10个就要扩容,底层就要创建新的数组)arraylist可以存储null值。

    • arraylist是不同步的,即不保证线程安全的。

    • 扩容机制是按照1.5倍进行扩容的,选择初始容量的时候要进行斟酌。

    • arraylistlist方法与collention中的方法完全一致!存储都是有序的,且可以有重复

    • linkedlist

      • 底层使用链表实现,方法与arraylist相同,允许存储null值,

      • linkedlist是不保证线程安全的。

      • collention接口中的方法,arraylist中的方法,linkedlist都可以使用。

      • arraylist linkedlist的优缺点:

        arraylist

        linkedlist

        底层以数组实现所以通过下标取值、赋值效率高,在内存上的地址是连续的

        底层是链表结构实现的,所以通过下标取值赋值效率低。在内存上是不联系的

        添加删除元素效率低

        添加删除元素效率高

      • linkedlist因为以链表实现的集合,操作开头和结尾方便,所以其提供了除list之外的常见方法外,还提供了专门操作开头和结尾元素的方法,例如 addfirst()addlast()等方法。

    set

    • setcollention的子接口

    • set集合不包含重复元素

    • set接口中的方法与collention中的方法一模一样,set中的元素不允许有重复的值。添加成功返回true,不成功返回false

    hashset

    • 类 是set 的实现类,不允许有重复元素,不保证迭代顺序(也就是无序的,也就是输出的结果跟插入的顺序不一致。),不保证线程安全。所以hashset的方法与collention方法一致,允许null值。

    hashcode:利用hashset存储自动以对象,使去除重复,就是想要保证自定义对象去重

     → 在自定义类中重写equalshashcode方法即可,当hashcode相同的时候才会去执行equals,如果hashcode直接不同了,那么equals将不用再执行了。

  • treeset

    • treesetset的常见的子实现类,只要是set的子类都不能存储相同元素)(也就是不允许元素重复),并且set下的实现类都不能通过下标操作

    • treeset是对元素进行自然顺序(默认升序)排序,或者根据创建set的时候提供comparator进行排序。

    • treeset是不保证线程安全的。

    • 基于treemap实现,使用元素的自然顺序对元素进行排序。且树是没有容量的。

    • 从写自定义对象时,该对象的类需要实现comparable接口,重写其comparto方法。

    • 例如存储学生对象,按年龄排序。

      • 重写comparto方法 ,return返回0只存第一个,返回负数和正数都能够排序,具体效果经过尝试。

      linkedhashsetlinked hashset的结合体,能保证数据不重复并且有序(按照输入顺序排序)