集合

集合概述:

  • 集合类用来存放对象
  • 相当于一个容器,包含着一组对象
  • 其中的每个对象作为集合的一个元素出现

数组与集合的比较

  • 数组也是容器,定长,访问速度快,不会自动扩充
  • 数组可以包含基本数据类型或引用数据类型的对象,集合只能包含引用类型的对象

Collection接口

  • 一组称为元素的对象
  • 一个Collection中可以放不同类型的数据
  • 是Set接口和List接口的父类
  • 是否有特定的顺序以及是否允许重复,取决于它的实现
    • Set 无序的集合:不允许重复
      -HashSet
    • List 有序的集合:允许重复
      -ArrayList
      -LinkedList

Set接口

  • 用来包含一组无序无重复的对象
    • 无序:指元素存入顺序和集合内存储的顺序不同
    • 无重复:两个对象e1,e2,如果e1.equals(e2)返回true,则认为e1和e2重复,在set中只留一个

Set接口的实现类

  • HashSet- 特性:内部对象的散列存取,即采用哈希技术
  • TreeSet- 存入的顺序跟存储的顺序不同,但是存储是按照排序存储的

使用foreach方式遍历Set集合

List接口

  • 用来包含一组有序有重复的对象

  • List中的元素都对应一个整数型的序号,记载其正在容器中的位置,可以根据序号存取容器中的元素

  • List有两种主要的集合实现类:

    • ArrayList
    • LinkedList
  • 两个实现类的区别

    ArrayList

  • Array是线性顺序存储的,是一种线性表

  • 它的特性和数组很接近,数组大小是不变的,而ArrayList的大小是可以动态改变的
    LinkedList

  • 是数据结构中链表的java实现

  • 相对于List来说,LinkedList最主要的功能方面的增强是可以在List的头部和尾部添加,删除,取得元素,直接提供了这些方法的实现。所以它可以非常方便的实现我们数据结构中的常见栈,队列等。

    ArrayList和LinkedList的比较
    存储结构:
    -ArrayList是线性顺序存储
    -LinkedList对象间彼此串联起来的一个链表
    操作性能:
    -ArrayList适合随机查询的场合
    -LinkedList元素的插入和删除操作性高

Map接口

  • 存储的是键值对,通过"键"对象查询"值"对象
  • key值不能重复

两个实现:

  • HashMap 按Hash算法存储
  • Tree 是排序(按key排序)存储的
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Java集合类可用于存储数量不等的对象,并可以实现常用的数据结构如栈,队列等,Java集合还可以用于保存具有映射关...
    小徐andorid阅读 5,960评论 0 13
  • 集合类框架的介绍: ![Java 集合类框架](https://upload-images.jianshu.io/...
    LynnGuo阅读 4,075评论 0 1
  • 四、集合框架 1:String类:字符串(重点) (1)多个字符组成的一个序列,叫字符串。生活中很多数据的描述都采...
    佘大将军阅读 4,138评论 0 2
  • 在编程中,常常需要集中存放多个数据。集合类主要负责保存、盛装其他数据,因此集合类也被称为容器类。所有的集合类都位于...
    一一一二二三阅读 3,126评论 0 1
  • ​ 在编写java程序中,我们最常用的除了八种基本数据类型,String对象外还有一个集合类,在我们的的程序中到处...
    Java帮帮阅读 5,314评论 0 6