经典的java面试题

经典的java面试题

ID:31645866

大小:55.43 KB

页数:5页

时间:2019-01-16

经典的java面试题_第1页
经典的java面试题_第2页
经典的java面试题_第3页
经典的java面试题_第4页
经典的java面试题_第5页
资源描述:

《经典的java面试题》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、经典的Java面试题^^述:还在做无准备的面试吗?还在为找不到java的面试题而苦恼吗?那么你就一定不能错过以下小编为你量身打造的java面试题集合了!让我们一起来看看这里有10个经典的java面试题,同时小编也为大家列出了答案。这是java开发人员面试经常容易遇到的问题,相信你了解和掌握之后一定会有所提高。让我们一起来看看吧。的Hashmap是如何工作的?Hashmap是一个针对数据结构的键值,每个键都会有相应的值,关键是识别这样的值。Hashmap基于hashing原理,我们通过put和get方法储存和获取对象。当我们将键值对传递给put方法

2、时,它调用键对象的hashcode方法来计算hashcode,让后找到bucket位置来储存值对象。当获取对象时,通过键对象的equals方法找到正确的键值对,然后返回值对象。Hashmap使用LinkedList来解决碰撞问题,当发生碰撞了,对象将会储存在LinkedList的下一个节点中。Hashmap在每个LinkedList节点中储存键值对对象。2•什么是快速失败的故障安全迭代器?快速失败的java迭代器可能会引发concurrentmodifcationException在底层集合迭代过程中被修改。故障安全作为发生在实例中的一个副本迭代

3、是不会抛出任何异常的。快速失败的故障安全范例定义了当遭遇故障时系统是如何反应的。例如,用于失败的快速迭代器ArrayList和用于故障安全的迭代器concurrentHashmapo是什么?javaBlockingQueue是一个并发集合util包的一部分。BlockingQueue队列是一种支持操作,它等待元素变得可用时来检索,同样等待空间可用时来存储元素。4•什么时候使用concurrentHashmap?在问题2中我们看到concurrentHashmap被作为故障安全迭代器的一个实例,它允许完整的并发检索和更新。当有大量的并发更新时,co

4、ncurrentHashmap此时可以被使用。这非常类似于Hashtable,但concurrentHashmap不锁定整个表来提供并发,所以从这点上concurrentHashmap的性能似乎更好一些。所以当有大量更新时concurrentHashmap应该被使用。5.哪一个List实现了最快插入?LinkedList和ArrayList是另个不同变量列表的实现。ArrayList的优势在于动态的增长数组,非常适合初始时总长度未知的情况下使用。LinkedList的优势在于在中间位置插入和删除操作,速度是最快的。LinkedList实现了Lis

5、t接口,允许null元素。此外LinkedList提供额外的get,remove,insert方法在LinkedList的首部或尾部。这些操作使LinkedList可被用作堆栈,队列或双向队列。ArrayList实现了可变大小的数组。它允许所有元素,包括null。每个ArrayList实例都有一个容量,即用于存储元素的数组的大小。这个容量可随着不断添加新元素而自动增加,但是增长算法并没有定义。当需要插入大量元素时,在插入前可以调用ensurecapacity方法来增加ArrayList的容量以提高插入效率。和Listlterator的区别List

6、lterator有add方法,可以向List中添加对象,而Iterator不能。ListIterator和Iterator都有hasNext和next方法,可以实现顺序向后遍历,但是Listlterator有hasPrevious和previous方法,可以实现逆向遍历。Iterator就不可以。Listlterator可以定位当前的索引位置,nextlndex和previouslndex可以实现。Iterator没有此功能。都可实现删除对象,但是Listlterator可以实现对象的修改,set方法可以实现。Iierator仅能遍历,不能修改。

7、7•什么是copyonwriteArrayList,它与ArrayList有何不同?copyonwriteArrayList是ArrayList的一个线程安全的变体,其中所有可变操作都是通过对底层数组进行一次新的复制来实现的。相比较于ArrayList它的写操作要慢一些,因为它需要实例的快照。copyonwriteArrayList中写操作需要大面积复制数组,所以性能肯定很差,但是读操作因为操作的对象和写操作不是同一个对象,读之间也不需要加锁,读和写之间的同步处理只是在写完后通过一个简单的〃二〃将引用指向新的数组对象上来,这个几乎不需要时间,这样

8、读操作就很快很安全,适合在多线程里使用,绝对不会发生concurrentmodificationException,因此copyonwr

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。