JAVA标准容器类的总结

 

     1. 数组把对象和数字形式的下标联系起来。它持有的是类型确定的对象,这样提取对象的时候就不用再作类型传递了。它可以是多维的,也可以持有primitive。但是创建之后它的容量不能改了。 

 

     2. Collection持有单个元素,而Map持有相关联的pair。 

 
     3. 和数组一样,List也把数字下标同对象联系起来,你可以把数组和List想成有序的容器。List会随元素的增加自动调整容量;但是List只能持有Object reference,所以不能存放primitive,而且把Object提取出来之后,还要做类型传递。

 

     4. 如果要作很多随机访问,那么请用ArrayList,但是如果要在List的中间作很多插入和删除的话,就应该用LinkedList了。


     5. LinkedList能提供队列,双向队列和栈的功能。


     6. Map提供的不是对象与数组的关联,而是对象和对象的关联。HashMap看重的是访问速度,而TreeMap更看重键的顺序,因而它不如HashMap那么快。而LinkedHashMap则保持对象插入的顺序,但是也可以用LRU算法为它重新排序。


     7. Set只接受不重复的对象。HashSet提供了最快的查询速度,而TreeSet则保持元素有序。LinkedHashSet保持元素的插入顺序。

 
     8. 没必要再在新代码里使用旧类库留下来的Vector,Hashtable和Stack了。


     容器类库是你每天都会用到的工具,它能使程序更简洁,更强大并且更高效。

    

                                                       以上内容摘自:Think in java

 

    

你可能感兴趣的:(java,算法)