Java集合框架
(例如基本的数据结构)里包含了最常见的Java常见面试问题。很好地理解集合框架,可以帮助你理解和利用Java的一些高级特性。
常见的数据结构
数组是最常用的数据结构。数组的特点是长度固定,可以用下标索引,并且所有的元素的类型都是一致的。数组常用的场景有把:从数据库里读取雇员的信息存储为EmployeeDetail[],把一个字符串转换并存储到一个字节数组中便于操作和处理,等等。尽量把数组封装在一个类里,防止数据被错误的操作弄乱。另外,这一点也适合其他的数据结构。
列表和数组很相似,只不过它的大小可以改变。列表一般都是通过一个固定大小的数组来实现的,并且会在需要的时候自动调整大小。列表里可以包含重复的元素。常用的场景有,添加一行新的项到订单列表里,把所有过期的商品移出商品列表,等等。一般会把列表初始化成一个合适的大小,以减少调整大小的次数。
集合和列表很相似,不过它不能放重复的元素。当你需要存储不同的元素时,你可以使用集合。
堆栈只允许对最后插入的元素进行操作(也就是后进先出,Last In First Out – LIFO)。如果你移除了栈顶的元素,那么你可以操作倒数第二个元素,依次类推。这种后进先出的方式是通过仅有的peek(),push()和pop()这几个方法的强制性限制达到的。这种结构在很多场景下都非常实用,例如解析像(4+2)*3这样的数学表达式,把源码中的方法和异常按照他们出现的顺序放到堆栈中,检查你的代码看看小括号和花括号是不是匹配的,等等。
常被面试官问到的问题
1.为什么Map接口不继承Collection 接口?
Set是无序集合,并且不允许重复的元素
List是有序的集合,并且允许重复的元素
而Map是键值对
它被视为是键的set和值的set的组合
Map被设计为键值对的集合,所以不需要继承Collection 接口
2.HashMap和Hashtable之间的区别?
同步或线程安全
Null键和Null值
迭代值
默认容量大小
3.comparable 和 comparator的不同之处?
comparable接口实际上是出自java.lang包
它有一个 compareTo(Object obj)方法来将objects排序
comparator接口实际上是出自 java.util 包
它有一个compare(Object obj1, Object obj2)方法来将objects排序
4.如何对Object的list排序?
对objects数组进行排序,我们可以用Arrays.sort()方法
如果要对objects的集合进行排序,需要使用Collections.sort()方法
5. fail-fast 与 fail-safe 之间的区别?
Fail fast快速地报告任何的failure。无论何时任何一个问题都会引发 fail fast系统fails
在Java Fail fast 迭代器中,迭代objects集合有时会出现并发修改异常,出现这种情况有2个原因
如果一个线程正在迭代一个集合,而另一个线程同时试图修改这个集合
在调用remove()方法后,如何我们还试图去修改集合object
6. Iterator、ListIterator 和 Enumeration的区别?
Enumeration接口在Java1.2版本开始有,所以Enumeration是合法规范的接口
Enumeration使用elements()方法
Iterator对所有Java集合类都有实现
Iterator使用iterator方法
Iterator只能往一个方向前进
ListIterator仅仅对List类型的类实现了
ListIterator使用listIterator()方法
7.Java 中 Set 与 List 有什么不同?
Set是一个不允许重复元素存在的集合
Set没有索引
Set仅仅允许一个null值
Set有类:HashSet、LinkedHashMap、TreeSet
List有索引
List允许N个null值
List可以按插入顺序显示
List有类:Vector、ArrayList、LinkedList
8. arraylist 与 vector 的区别?
Vector 在Java的第一个版本就引入了,也就是说vector是一个合法规范的类
ArrayList在Java1.2版本引入的,是Java 集合框架的组成部分
Vector是同步的
ArrayList是不同步的
9.什么类实现了List接口?
ArrayList
LinkedList
Vector
10.什么类实现了Set接口?
HashSet
LinkedHashSet
TreeSet
11.如何保证一个集合线程安全?
Vector, Hashtable, Properties 和 Stack 都是同步的类,所以它们都线程安全的,可以被使用在多线程环境中
使用Collections.synchronizedList(list)) 方法,可以保证list类是线程安全的
使用java.util.Collections.synchronizedSet()方法可以保证set类是线程安全的
12.是否可以往 TreeSet 或者 HashSet 中添加 null 元素?
可以往 hashset 中添加一个 null
TreeSet 也允许一个 null值
13.解释下Collection的接口继承关系?
14.Iterator符合哪个设计模式?
Iterator 设计模式
15.HashSet 实现了哪个数据结构?
HashSet 内部实现了hashmap
16.为什么 Collection 不能继承 Cloneable 和 Serializable?
List和Set唯一继承 Collection 接口
SortedMap 继承了 Map 接口
17.hashCode() 和 equals() 方法的重要性?如何在Java中使用它们?
hashCode() 和 equals() 方法定义在”object”类中
如果equals() 方法在比较2个对象时返回true,那么hashCode()的返回值必须得一样
18.array 和 arraylist 的区别?
Array类似object集合类型,大小固定
Arraylist是同质和异质元素的集合
19.什么是 Properties 类?
Properties 是Hashtable的子类。它被用于维护值的list,其中它们的键、值都是String类型
20.如何将一个字符串转换为arraylist?
使用 arrayList.toArray() 方法