集合的概念
现实生活中:很多的事物凑在一起。
数学中的集合:具有共同属性的事物的总体。
Java中的集合类:是一种工具类,就像是容器,存储任意数量的具有共同属性的对象。
集合的作用
1.在类的内部,对数据进行组织。
2.简单而快速的搜索大数量的条目。
3.有的集合接口,提供了一系列排列有序的元素,并且可以在序列中间快速的插入/删除有关元素。
4.有的集合接口,提供了映射关系,可以通过关键字(key)去快速查找到对应的唯一对象,而这个关键字可以是任意类型。
集合与数组的区别
数组声明了它容纳的元素的类型,而集合不声明。这是由于集合以object形式来存储它们的元素。
数组的长度固定,集合长度可变。
数组只能通过下标访问元素,下标的类型固定是整型,当不知道元素的位置时,需要遍历,而有的集合可以通过任意类型查找所映射的具体对象。
数组是一种可读/可写数据结构没有办法创建一个只读数组。然而可以使用集合提供的ReadOnly方 只读方式来使用集合。该方法将返回一个集合的只读版本。
java集合框架的体系结构
由两大家族组成:
collection接口:是List、set、Queue接口的父接口,定义了可用于操作List、set、Queue的方法–增删改查。和Map接口
collection包括:
List:序列。常用的,存储的元素是排列有序的,并且可以重复,可以精确的控制每个元素的插入位置,或者删除某个位置元素。Arraylist:数组序列list的实现类,底层是由数组实现的。
Queue:队列。存储的元素是排列有序的,并且可以重复。LinkedList:链表,Queue的实现类,同时也是list的实现类
Set。集:常用的,存储的元素是排列无序的,并且不可以重复。如何区分是否重复:Set里的元素是不能重复的,那么用iterator()方法。equals()是判读两个Set是否相等。
equals()和==方法决定引用值是否指向同一对象 equals()在类中被覆盖,为的是当两个分离的对象的内容和类型相配的话,返回真值。
HashSet:哈希集,Set的实现类
Map:重要的是HashMap实现类。
它们内部如何来存储对象,collection中存储的是一个一个的对象,Map:中运用<key,Value>
键值对key和value可以是任意类型的对象,用两个对象,一个映射来存储对象。
list操作数据
添加
boolean add(E e)
:向列表的尾部添加指定的元素,e表示要添加的元素。
//创建list,以及要添加的元素
List coursesToSelec