集合
-
集合、数组都是对多个数据进行存储操作的结构,简称Java容器。
说明:此时的存储,主要指的是内存层面的存储,不涉及到持久化的存储(.txt,.jpg,.avi,数据库中)
-
数组在存储多个数据方面的特点
-
一旦初始化以后,其长度就确定了
-
(比如:String[] arr; int[] arr1;Object[] arr2;)
-
-
数组在存储多个数据方面的缺点
-
一旦初始化以后,其长度就不可修改
-
数组中提供的方法非常有限,对于添加、删除、插入数据等操作,非常不便,同时效率不高
-
获取数组中实际元素的个数的需求,数组没有现成的属性或方法可用
-
数组存储数据的特点:有序、可重复。对于无序、不可重复的需求,不能满足。
-
集合框架
-
Collection接口:单列集合,用来存储一个一个的对象
-
List接口:存储有序的、可重复的数据。 -->"动态"数组
-
ArrayList、LinkList、Vector
-
-
Set接口:存储无序的、不可重复的数据 -->高中讲的"集合"
-
HashSet 、LinkedHashSet 、TreeSet
-
-
-
Map接口:双列集合,用来存储一对(Key - value)一对的数据 -->高中函数:y=f(x)
-
HashMap 、LinkedHashMap、TreeMap、Hashtable、Properties
-
Collection接口中方法的使用
add(Object e):将元素e添加到集合coll中 size();获取添加元素的个数 addAll():將coll0集合中的元素添加到当前的集合中 clear():清空集合元素 isEmpty():判断当前集合是否为空 向Collection接口的实现类的对象中添加数据obj时,要求obj所在类要重写equals(). contains(Object obj):判断当前集合中是否包含obj containsAll(Collection coll1):判断形参coll1中的所有元素是否都存在于当前集合中。 remove(Object object):从当前集合中移除obj元素 removeAll(Collection coll1):差集:从当前集合中移除coll1中所有的元素 retainAll(Collection coll1):交集:获取当前集合和coll1集合的交集,并返回给当前集合(保留一样的,删除不一样的) equals(Object object): 当前集合和形参集合的元素都相同,返回true hashCode(): 返回当前对象的哈希值 集合---->数组:toArray() 拓展:数组--->集合:调用Arrays类的静态方法asList()