一、为什么要使用集合
单个数据,可以用变量保存;
多个数据,可以用数组保存;
但是对于存储多个数据且数量不确定的情况,使用集合;
二、集合和数组的区别
(1)数组:
1、只能保存同一种类型的数据;
2、数组一旦创建,容量不可改变;
3、数组可以保存引用类型的数据和基本类型的数据;
(2)集合:
1、可以保存不同类型的数据;
2、集合可根据需要自动扩容;
3、集合只能保存引用类型的数据;
那么有个问题,为什么集合能存放引用类型?
原因:
集合的存在就是为了方便对多个对象的操作才出现的,存放的是对象的引用,实际内容都在堆上面或者方法区里面,但是基本数据类型是在栈上分配空间的。
想把基本数据类型存入集合中,直接存就可以了,系统会自动将其装箱成封装类。
(3)泛型
Java集合有个缺点,把一个对象丢进集合后,集合会忘记这个对象的数据类型,再次取出时,系统自动把它变成了Object类型。
为了解决这种问题,泛型出现了。
Java引入了参数化类型的概念,允许程序在创建集合时指定集合元素的类型,Java的这种参数化类型被称为泛型。如:List<String>表明这个List中只能保存字符串类型的对象。
需要注意的是,泛型只能是对象,所以如果想保存基本数据类型时,可以使用基本类型的包装类。如List<Integer>等
三、集合中的层次关系
(1)Collection接口是集合类的根接口,没有实现类,但是有两个继承的接口,即List和Set。
特点:Set中不能包含重复的元素。List是一个有序的集合,可以包含重复的元素,提供了按索引访问的方式。
(2)Map是Java.util包中的另一个接口,它和Collection接口没有关系,是相互独立的,但是都属于集合类的一部分。Map包含了key-value对。
特点:Map不能包含重复的key,但是可以包含相同的value。
(3)Iterator,所有的集合类,都实现了Iterator接口,这是一个用于遍历集合中元素的接口,主要包含以下三种方法:
1.hasNext()是否还有下一个元素。
2.next()返回下一个元素。
3.remove()删除当前元素。
四、对于List、Set、Map简单应用
(1)Set
特点:不可重复
主要有两个实现类:hashSet和treeSet
HashSet类按照哈希算法来存取集合中的对象,存取速度比较快。
TreeSet类实现了SortedSet接口,能够对集合中的对象进行排序。
Set用法:
1 Set set=new HashSet(); 2 String s1=new String("hello"); 3 String s2=s1; 4 String s3=new String("world"); 5 set.add(s1); 6 set.add(s2); 7 set.add(s3); 8 System.out.println(set.size());//打印集合中对象的数目为 2
(2)List
特点:线性方式存储,可重复
主要有两个实现类:ArrayList和LinkedList
ArrayList() : 长度可变数组。可以对元素进行随机的访问,向ArrayList()中插入与与删除元素的速度慢。
LinkedList(): 链表。插入和删除速度快,访问速度慢。
List用法:
1 List list = new ArrayList(); 2 list.add(1); 3 list.add(2); 4 list.add(3); 5 list.add(4); 6 //1: 用for循环和get()方法 7 for(int i=0; i<list.size();i++){ 8 System.out.println(list.get(i)); 9 } 10 //2: 使用 迭代器(Iterator) 11 Iterator iterator = list.iterator(); 12 while(iterator.hasNext()){ 13 System.out.println(iterator.next()); 14 }
(3)Map
特点:键值对,值可以重复
Map用法:
1 public class t1 { 2 public static void main(String[] args) 3 { 4 HashMap hashmap = new HashMap(); 5 hashmap.put("Item0","Value0"); 6 hashmap.put("Item1","Value1"); 7 hashmap.put("Item2","Value2"); 8 hashmap.put("Item3","Value3"); 9 Set set = hashmap.entrySet(); 10 Iterator iterator = set.iterator(); 11 while(iterator.hasNext()) 12 { 13 Map.Entry mapentry = (Map.Entry)iterator.next(); 14 System.out.println(mapentry.getKey()+"/"+mapentry.getValue()); 15 } 16 17 } 18 }
五、关于 ArrayList 与 LinkedList 的比较分析
ArrayList 底层采用数组实现,LinkedList 底层采用双向链表实现。
随机访问,arrayList速度快,插入和删除linkedList快