java集合面试题大全(java面试集合基础题)

来自:evget.com/article/2014/11/27/21869.html

10 个经典的 Java 集合面试题,看你能否答得上来?

这里有10个经典的Java面试题,也为大家列出了答案。这是Java开发人员面试经常容易遇到的问题,相信你了解和掌握之后一定会有所提高。

让我们一起来看看吧。

1.Java的HashMap是如何工作的?

HashMap是一个针对数据结构的键值,每个键都会有相应的值,关键是识别这样的值。

HashMap 基于 hashing 原理,我们通过 put ()和 get ()方法储存和获取对象。当我们将键值对传递给 put ()方法时,它调用键对象的 hashCode ()方法来计算 hashcode,让后找到 bucket 位置来储存值对象。

当获取对象时,通过键对象的 equals ()方法找到正确的键值对,然后返回值对象。HashMap 使用 LinkedList 来解决碰撞问题,当发生碰撞了,对象将会储存在 LinkedList 的下一个节点中。HashMap 在每个 LinkedList 节点中储存键值对对象。

2.什么是快速失败的故障安全迭代器?

快速失败的Java迭代器可能会引发ConcurrentModifcationException在底层集合迭代过程中被修改。故障安全作为发生在实例中的一个副本迭代是不会抛出任何异常的。

快速失败的故障安全范例定义了当遭遇故障时系统是如何反应的。例如,用于失败的快速迭代器ArrayList和用于故障安全的迭代器ConcurrentHashMap。

3.Java BlockingQueue是什么?

Java BlockingQueue是一个并发集合util包的一部分。BlockingQueue队列是一种支持操作,它等待元素变得可用时来检索,同样等待空间可用时来存储元素。

4.什么时候使用ConcurrentHashMap?

在问题2中我们看到ConcurrentHashMap被作为故障安全迭代器的一个实例,它允许完整的并发检索和更新。当有大量的并发更新时,ConcurrentHashMap此时可以被使用。

这非常类似于Hashtable,但ConcurrentHashMap不锁定整个表来提供并发,所以从这点上ConcurrentHashMap的性能似乎更好一些。所以当有大量更新时ConcurrentHashMap应该被使用。

5.哪一个List实现了最快插入?

LinkedList和ArrayList是另个不同变量列表的实现。ArrayList的优势在于动态的增长数组,非常适合初始时总长度未知的情况下使用。LinkedList的优势在于在中间位置插入和删除操作,速度是最快的。

LinkedList实现了List接口,允许null元素。此外LinkedList提供额外的get,remove,insert方法在LinkedList的首部或尾部。这些操作使LinkedList可被用作堆栈(stack),队列(queue)或双向队列(deque)。

ArrayList实现了可变大小的数组。它允许所有元素,包括null。每个ArrayList实例都有一个容量(Capacity),即用于存储元素的数组的大小。这个容量可随着不断添加新元素而自动增加,但是增长算法并没有定义。当需要插入大量元素时,在插入前可以调用ensureCapacity方法来增加ArrayList的容量以提高插入效率。

6.Iterator和ListIterator的区别

●ListIterator有add()方法,可以向List中添加对象,而Iterator不能。

●ListIterator和Iterator都有hasNext()和next()方法,可以实现顺序向后遍历,但是ListIterator有hasPrevious()和previous()方法,可以实现逆向(顺序向前)遍历。Iterator就不可以。

●ListIterator可以定位当前的索引位置,nextIndex()和previousIndex()可以实现。Iterator没有此功能。

●都可实现删除对象,但是ListIterator可以实现对象的修改,set()方法可以实现。Iierator仅能遍历,不能修改。

7.什么是CopyOnWriteArrayList,它与ArrayList有何不同?

CopyOnWriteArrayList是ArrayList的一个线程安全的变体,其中所有可变操作(add、set等等)都是通过对底层数组进行一次新的复制来实现的。相比较于ArrayList它的写操作要慢一些,因为它需要实例的快照。

CopyOnWriteArrayList中写操作需要大面积复制数组,所以性能肯定很差,但是读操作因为操作的对象和写操作不是同一个对象,读之间也不需要加锁,读和写之间的同步处理只是在写完后通过一个简单的'='将引用指向新的数组对象上来,这个几乎不需要时间,这样读操作就很快很安全,适合在多线程里使用,绝对不会发生ConcurrentModificationException ,因此CopyOnWriteArrayList适合使用在读操作远远大于写操作的场景里,比如缓存。

8.迭代器和枚举之间的区别

如果面试官问这个问题,那么他的意图一定是让你区分Iterator不同于Enumeration的两个方面:

●Iterator允许移除从底层集合的元素。

●Iterator的方法名是标准化的。

9.Hashmap如何同步?

当我们需要一个同步的HashMap时,有两种选择:

●使用Collections.synchronizedMap(..)来同步HashMap。

●使用ConcurrentHashMap的

这两个选项之间的首选是使用ConcurrentHashMap,这是因为我们不需要锁定整个对象,以及通过ConcurrentHashMap分区地图来获得锁。

10.IdentityHashMap和HashMap的区别

IdentityHashMap是Map接口的实现。不同于HashMap的,这里采用参考平等。

●在HashMap中如果两个元素是相等的,则key1.equals(key2)

●在IdentityHashMap中如果两个元素是相等的,则key1 == key2

对了,在这里说一下,我目前是在职Java开发,如果你现在正在学习Java,了解Java,渴望成为一名合格的Java开发工程师,在入门学习Java的过程当中缺乏基础入门的视频教程,可以关注并私信我:01。获取。我这里有最新的Java基础全套视频教程。

本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:dandanxi6@qq.com

(0)
上一篇 2023-10-14 12:54
下一篇 2023-10-14 13:56

相关推荐

  • 普法带你读懂预防未成年人犯罪法

    少年儿童是祖国的未来、民族的希望。预防未成年人违法犯罪工作事关改革发展稳定大局。2021年,新修订的未成年人保护法和预防未成年人犯罪法正式施行。下面,就和小编一起,了解下具体内容吧…

    职场百科 2023-09-16
  • 农民怎样才能享受到国家三农政策的红利呢

    农民怎么样才能够享受到国家三农政策的红利?近些年对三农的重视和发展也愈渐增加。 现在也出台了对于三农政策相对应的扶持和帮助,甚至各项的补贴。那作为一个农民,我们如何才能够更好的享受…

    2023-07-29
  • 领导提拔人的五种特征(领导破格提拔的人都有这五种特质)

    在职场中,许多人都希望自己能够晋升,没有人希望自己一辈子都当一个小员工。 小A是一家公司的员工,她入职快要3年了,每年都非常努力地工作,但总是得不到晋升的机会,她的业绩和能力也是有…

    2023-04-14
  • 电话销售开场白话术(卖房电话销售背熟10句开场白话术)

    在电话和网络的一个角落 学员和学习规划师美好小事正悄悄发生 那温暖的小小火焰 正在这世界的某个角落点亮 01 熊欣,来自湖北孝感,2017年12月15号加入尚德机构,在尚德一年半的…

    2023-05-27
  • 年终奖个税有新变化(个税申报年终奖在哪选)

    正在持续完善 从2022年1月1日起 居民个人取得全年一次性奖金 需并入当年综合所得计算缴纳个人所得税 今年年终奖仍然可以单独计算个税 不计入综合所得 全年收入不超过6万元的纳税人…

    2023-03-20
  • 页码首页不显示从第二页开始

    一份长文档中,通常有封面、目录、正文内容等等。而我们在设置页码时,如果不作其它设置,页码都是从封面开始。为了不让封面也显示页码,而第二页设置页码从1开始,这个该怎么设置呢? 其实方…

    2023-05-14
  • 员工最希望老板做的事是什么

    ,我们应该从不同的层面来分析。 首先,我们换位思考一下,如果,你是老板,你希望自己的员工是什么样的?自己到底是想要一个什么样的员工团队。老板们肯定都喜欢那种既听话同时又有自己独特的…

    职场百科 2023-01-10
  • 提高表达能力的方法和技巧,提高表达能力的九种方法

    有一个案例,说一个姑娘把自己的男朋友带回家, 恰好姑娘妈妈的朋友也在场,阿姨看到姑娘的男朋友以后,站起来说了一句经典的话“这孩子,眼光和你妈一样好”。这个故事我看过以后,惊为天人,…

    2022-12-22
  • 社会学类包括哪些专业

    专业类介绍第 8 期 01. 什么是社会学 社会学是系统地研究社会行为与人类群体的学科,起源于19世纪三四十年代,是从社会哲学演化出来的一门现代学科。 社会学是一门具有多重研究方式…

    2023-05-17
  • 公益淘宝店怎么开

     现在淘宝上,有些店铺参与了公益宝贝的计划,它是指只要店铺的某个宝贝卖出去了,卖家就会捐一部分的钱给慈善机构,其实卖家参与,不仅做了公益,还给店铺带来了权重提升的好处,那么怎么做这…

    职场百科 2023-05-05