【容器】算法
18. Java 容器都有哪些?数组
19. Collection 和 Collections 有什么区别?安全
20. List、Set、Map 之间的区别是什么?数据结构
List、Set、Map 的区别主要体如今两个方面:元素是否有序、是否容许元素重复。多线程
三者之间的区别,以下表:并发
21. HashMap 和 Hashtable 有什么区别? 框架
22. 如何决定使用 HashMap 仍是 TreeMap? 工具
对于在 Map 中插入、删除、定位一个元素这类操做,HashMap 是最好的选择,由于相对而言 HashMap 的插入会更快,但若是你要对一个 key 集合进行有序的遍历,那 TreeMap 是更好的选择。性能
23. 说一下 HashMap 的实现原理?spa
HashMap 基于 Hash 算法实现的,咱们经过 put(key,value)存储,get(key)来获取。当传入 key 时,HashMap 会根据 key. hashCode() 计算出 hash 值,根据 hash 值将 value 保存在 bucket 里。当计算出的 hash 值相同时,咱们称之为 hash 冲突,HashMap 的作法是用链表和红黑树存储相同 hash 值的 value。当 hash 冲突的个数比较少时,使用链表不然使用红黑树。(注:使用红黑树是在jdk1.8以后作的改进)
24. 说一下 HashSet 的实现原理?
HashSet 是基于 HashMap 实现的,HashSet 底层使用 HashMap 来保存全部元素,所以 HashSet 的实现比较简单,相关 HashSet 的操做,基本上都是直接调用底层 HashMap 的相关方法来完成,HashSet 不容许重复的值。
25. ArrayList 和 LinkedList 的区别是什么?
综合来讲,在须要频繁读取集合中的元素时,更推荐使用 ArrayList,而在插入和删除操做较多时,更推荐使用 LinkedList。
26. 如何实现数组和 List 之间的转换?
代码示例:
// list to array List<String> list = new ArrayList<String>(); list.add("akon"); list.add("blog"); list.toArray(); // array to list String[] array = new String[]{"akon","blog"}; Arrays.asList(array);
27. ArrayList 和 Vector 的区别是什么?
线程安全:Vector 使用了 Synchronized 来实现线程同步,是线程安全的,而 ArrayList 是非线程安全的。
性能:ArrayList 在性能方面要优于 Vector。
扩容:ArrayList 和 Vector 都会根据实际的须要动态的调整容量,只不过在 Vector 扩容每次会增长 1 倍,而 ArrayList 只会增长 50%。
28. Array 和 ArrayList 有何区别?
Array 能够存储基本数据类型和对象,ArrayList 只能存储对象。
Array 是指定固定大小的,而 ArrayList 大小是自动扩展的。
Array 内置方法没有 ArrayList 多,好比 addAll、removeAll、iteration 等方法只有 ArrayList 有。
29. 在 Queue 中 poll()和 remove()有什么区别?
相同点:都是返回第一个元素,并在队列中删除返回的对象。
不一样点:若是没有元素 poll()会返回 null,而 remove()会直接抛出 NoSuchElementException 异常。
代码示例:
Queue<String> queue = new LinkedList<String>(); queue.offer("string"); // add System.out.println(queue.poll()); System.out.println(queue.remove()); System.out.println(queue.size());
30. 哪些集合类是线程安全的?
Vector、Hashtable、Stack 都是线程安全的,而像 HashMap 则是非线程安全的,不过在 JDK 1.5 以后随着 Java. util. concurrent 并发包的出现,它们也有了本身对应的线程安全类,好比 HashMap 对应的线程安全类就是 ConcurrentHashMap。
31. 迭代器 Iterator 是什么?
Iterator 接口提供遍历任何 Collection 的接口。咱们能够从一个 Collection 中使用迭代器方法来获取迭代器实例。迭代器取代了 Java 集合框架中的 Enumeration,迭代器容许调用者在迭代过程当中移除元素。
32. Iterator 怎么使用?有什么特色?
Iterator 使用代码以下:
List<String> list = new ArrayList<>(); Iterator<String> it = list. iterator(); while(it. hasNext()){ String obj = it. next(); System.out.println(obj); }
Iterator 的特色是更加安全,由于它能够确保,在当前遍历的集合元素被更改的时候,就会抛出 ConcurrentModificationException 异常。
33. Iterator 和 ListIterator 有什么区别?
Iterator 能够遍历 Set 和 List 集合,而 ListIterator 只能遍历 List。
Iterator 只能单向遍历,而 ListIterator 能够双向遍历(向前/后遍历)。
ListIterator 从 Iterator 接口继承,而后添加了一些额外的功能,好比添加一个元素、替换一个元素、获取前面或后面元素的索引位置。
34. 怎么确保一个集合不能被修改?
可使用 Collections. unmodifiableCollection(Collection c) 方法来建立一个只读集合,这样改变集合的任何操做都会抛出 Java.lang.UnsupportedOperationException 异常。
示例代码以下:
List<String> list = new ArrayList<>(); list.add("x"); Collection<String> clist = Collections.unmodifiableCollection(list); clist.add("y"); // 运行时此行报错 System.out.println(list.size());