Java面试常见问题
虽然我这个阶段不需要找工作了,但没想到这个系列还能更新。和领导同事在闲聊时以及在实际工作中遇到过的比较有用的知识进行整理。Java的精髓就是OOP,在工程中面向对象开发中一层层之间的关系非常重要,必须对它非常清楚,才能高效工作,少走弯路。
interface和abstract的区别
- interface只能定义抽象方法不能实现方法,抽象类既可以定义抽象方法,也可以实现方法。
- 单继承,多实现。接口可以实现多个,只能继承一个抽象类。
- 接口强调的是功能,抽象类强调的是所属关系。
- 接口中的所有成员变量 为public static final, 静态不可修改,当然必须初始化。接口中的所有方法都是public abstract 公开抽象的。而且不能有构造方法。抽象类既可以有抽象方法也可以没有。
列举java的几种map,并分析各自适合的场景
Java文档中(Map (Java Platform SE 8 ) (oracle.com))列举了非常多的map实现:
- AbstractMap,
- Attributes,
- AuthProvider,
- ConcurrentHashMap
- ConcurrentSkipListMap
- EnumMap
- HashMap,
- Hashtable
- IdentityHashMap
- LinkedHashMap
- PrinterStateReasons
- Properties
- Provider
- RenderingHints
- SimpleBindings
- TabularDataSupport
- TreeMap
- UIDefaults,
- WeakHashMap
这里仅对常用的一些map进行分析
HashMap和Hashtable实现类:
HashMap与HashTable的区别:
- 同步性:Hashtable是同步的,这个类中的一些方法保证了Hashtable中的对象是线程安全的。而HashMap则是异步的,因此 HashMap中的对象并不是线程安全的。因为同步的要求会影响执行的效率,所以如果你不需要线程安全的集合那么使用HashMap是一个很好的选择,这 样可以避免由于同步带来的不必要的性能开销,从而提高效率。
- 值:HashMap可以让你将空值作为一个表的条目的key或value,但是Hashtable是不能放入空值的。HashMap最多只有一个key值为null,但可以有无数多个value值为null。
性能:HashMap的性能最好,HashTable的性能是最差(因为它是同步的)
对于Hash作为key,需要注意:
1)用作key的对象必须实现hashCode和equals方法。
2)不能保证其中的键值对的顺序
3)尽量不要使用可变对象作为它们的key值。
LinkedHashMap:
它的父类是HashMap,使用双向链表来维护键值对的次序,迭代顺序与键值对的插入顺序保持一致。LinkedHashMap需要维护元素的插入顺序,所以性能略低于HashMap,但在迭代访问元素时有很好的性能,因为它是以链表来维护内部顺序。
TreeMap:
Map接口派生了一个SortMap子接口,SortMap的实现类为TreeMap。TreeMap也是基于红黑树对所有的key进行排序,有两种排序 方式:自然排序和定制排序。Treemap的key以TreeSet的形式存储,对key的要求与TreeSet对元素的要求基本一致。
- Map.Entry firstEntry():返回最小key所对应的键值对,如Map为空,则返回null。
- Object firstKey():返回最小key,如果为空,则返回null。
- Map.Entry lastEntry():返回最大key所对应的键值对,如Map为空,则返回null。
- Object lastKey():返回最大key,如果为空,则返回null。
- Map.Entry higherEntry(Object key):返回位于key后一位的键值对,如果为空,则返回null。
- Map.Entry lowerEntry(Object key):返回位于key前一位的键值对,如果为空,则返回null。
- Object lowerKey(Object key):返回位于key前一位key值,如果为空,则返回null。
- NavigableMap subMap(Object fromKey,boolean fromlnclusive,Object toKey,boolean toInciusive):返回该Map的子Map,其key范围从fromKey到toKey。
- SortMap subMap(Object fromKey,Object toKey );返回该Map的子Map,其key范围从fromkey(包括)到tokey(不包括)。
- SortMap tailMap(Object fromkey ,boolean inclusive):返回该Map的子Map,其key范围大于fromkey(是否包括取决于第二个参数)的所有key。
- SortMap headMap(Object tokey ,boolean inclusive):返回该Map的子Map,其key范围小于tokey(是否包括取决于第二个参数)的所有key。
WeakHashMap:
WeakHashMap与HashMap的用法基本相同,区别在于:后者的key保留对象的强引用,即只要HashMap对象不被销毁,其对象所有key 所引用的对象不会被垃圾回收,HashMap也不会自动删除这些key所对应的键值对对象。但WeakHashMap的key所引用的对象没有被其他强引 用变量所引用,则这些key所引用的对象可能被回收。WeakHashMap中的每个key对象保存了实际对象的弱引用,当回收了该key所对应的实际对 象后,WeakHashMap会自动删除该key所对应的键值对。
IdentityHashMap类:
IdentityHashMap与HashMap基本相似,只是当两个key严格相等时,即key1==key2时,它才认为两个key是相等的 。IdentityHashMap也允许使用null,但不保证键值对之间的顺序。
EnumMap类:
- EnumMap中所有key都必须是单个枚举类的枚举值,创建EnumMap时必须显示或隐式指定它对应的枚举类。
- EnumMap根据key的自然顺序,即枚举值在枚举类中定义的顺序,来维护键值对的次序。
- EnumMap不允许使用null作为key值,但value可以。
java中enum获取索引操作
什么是线程安全,map是线程安全的吗,enum线程安全吗
线程安全:多线程访问同一代码,不会产生不同的结果。
在多线程环境中,当各线程不共享数据的时候,那么一定是线程安全的。但不共享数据的话多线程往往没有意义,所以在多数情况下还是需要共享数据的,这时就需要进行适当的同步控制了。前述HashMap是线程不安全的,而HashTable是同步的,是线程安全的,代价就是效率不如HashMap快。
枚举enum实例对应用static final修饰的变量,其初始化在静态块完成,所以是线程安全的