黑马程序员技术交流社区

标题: 【石家庄校区】java中常用的数据结构 [打印本页]

作者: xiekai_sjz    时间: 2018-5-18 14:54
标题: 【石家庄校区】java中常用的数据结构
    Java中有几种常用的数据结构,主要分为Collection和map两个主要接口(接口只提供方法,并不提供实现),而程序中最终使用的数据结构是继承自这些接口的数据结构类。

ListArrayList、LinkedList、Vector有什么区别?
如何使List线程安全
Collections.synchronizedList(list);
或者使用手动的方法保护线程安全。
List是有序的吗?
这里的有序指有序性,有序或无序是指是否按照其添加的顺序来存储对象,List是有序的。
List怎么实现排序?
实现排序,可以使用自定义排序
list.sort(new Comparator(){...})
或者使用Collections进行快速排序
Collections.sort(list)
List和Array之间如何互相转换?
SetSet与List有什么区别?HashSet、LinkedHashSet、TreeSet的区别?
都无法保证线程安全,底层都使用map实现不重复性(所以特性也在map中),Set都不能使用get(index)的方法获取元素,只能使用iterator进行获取。其中:
如何使Set线程安全
Collections.synchronizedSet(set);

Map
MapHashMap、LinkedHashMap、Hashtable、TreeMap的区别?
如何使Map线程安全
Collections.synchronizedMap(map);
什么样的对象适合做为键,有什么要求?
String、Interger这样的类是final类型的,具有不可变性,且重写了equals()和hashCode()方法。换言之,做为key的对象,不可变性是必要的,因为要计算hashCode(),要防止放入时和取出时hashcode不一致。此外还需要重写equals()和hashCode()方法,用于比较对象一致性。
HashMap初始化传入的容量参数的值就是HashMap实际分配的空间么?
不是,是比传入容量参数值大的最小的2的n次方,比如传入6,实际分配8。
HashMap的底层数据结构是什么?
是一个数组,结合了顺序表+单向链表的形式,内部的每一个节点都是Node对象.



出处: http://www.cnblogs.com/qbzf-Blog/





欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2