Java集合杂谈
在Java中有普通集合、同步(线程安全的集合)、并发集合。普通集合通常性能最高,但是不保证多线程的安全性和并发的可靠性。线程安全集合仅仅是给集合添加了synchronized同步锁,严重牺牲了性能,而且对并发的效率就更低了,并发集合则通过复杂的策略不仅保证了多线程的安全而且又提高了并发时的效率。
并发集合常见的有ConcurrentHashMap、ConcurrentLinkedQueue、ConcurrentLinkedDeque等。并发集合位于java.util.concurrent包下,时JDK1.5之后才有的。
Collections工具类提供了相关的API,可以让ArrayList、HashSet、HashMap不安全的集合变为安全的。
List的三个子类的特点
实现类 | 底层结构 | 线程安全 | 查询速度 | 增加删除速度 |
ArrayList | 数组 | 否 | 快 | 慢 |
LinkedList | 链表 | 否 | 慢 | 快 |
voctor | 数组 | 是 | 慢 | 慢 |
List和Set、Map的区别
结构方面:
List和Set是存储单列数据的集合,Map是存储键值对这样的双列数据的集合;List中存储的数据是有顺序,并且允许重复。Set中存储的数据是无序的,且不允许有重复,但元素在集合中的位置由元素的hashcode决定,位置是固定的(Set集合是根据hashcode来进行数据的存储,所以位置是固定的,但是位置不是用户可以控制的,所以对于用户来说Set中的元素还是无序的)。Map中存储的数据是没有顺序的,其键(Key)不能重复,值(Value)可以有重复。
实现类:
List接口有三个实现类(ArrayList:基于数组实现,非线程安全的,效率高,便于索引,但不便于插入删除;LinkedList:基于链表实现,链表内存是散乱的,每一个元素存储本身内存地址的同时还要存储下一个元素的地址。链表增加和删除快,查找慢;Vector:基于数组实现,线程安全的,效率低)。
Set接口有两个实现类(HashSet:底层是由HashMap实现,不允许集合中有重复的值,使用该方式时需要重写equals()和hashCode()方法;LinkedHashSet:继承于HashSet,同时又基于LinkedHashMap来进行实现,底层使用的是LinkedHashMap)。
Map接口有三个实现类(HashMap:基于hash表的Map接口实现,非线程安全,高效,支持null值和null键;HashTable:线程安全,低效,不支持null值和null键;LinkedHashMap:是HashMap的一个子类,保存了记录的插入顺序;SortMap接口:TreeMap,能够把它保存的记录根据键排序,默认是键值的升序排序)。
区别:
List集合中对象按照索引位置排序,可以有重复对象,允许按照对象在集合中的索引位置检索对象,例如通过list.get(i)方法来获取集合中的元素;Set集合中的对象不按照特定的方式排序,并且没有重复对象,但它的实现类能对集合中的对象按照特定的方式排序,例如TreeSet类,可以按照默认顺序,也可以通过实现Java.util.Comparator<Type>接口来自定义排序方式;Map中的每一个元素包含一个键和一个值,成对出现,键对象不可以重复,值对象可以重复。