首页 > 编程语言 >Java面试题(容器)

Java面试题(容器)

时间:2024-07-29 19:24:05浏览次数:23  
标签:容器 面试题 Java HashMap Iterator ArrayList List 线程 集合

目录

1、Java 容器都有哪些?

2、 Collection 和 Collections 有什么区别

3、List、Set、Map 之间的区别是什么?

4、 HashMap 和 Hashtable 有什么区别?

5、如何决定使用 HashMap 还是 TreeMap?

6、 说一下 HashMap 的实现原理?

7、 ArrayList 和 LinkedList 的区别是什么?

8、 如何实现数组和 List 之间的转换?

9、 ArrayList 和 Vector 的区别是什么?

10、 Array 和 ArrayList 有何区别?

11、 哪些集合类是线程安全的?

 12、迭代器 Iterator 是什么?

13、 Iterator 怎么使用?有什么特点?

14、 Iterator 和 ListIterator 有什么区别?

15、怎么确保一个集合不能被修改?


1、Java 容器都有哪些?

Java 容器分为 Collection 和 Map 两大类,其下又有很多子类,如下所示:
  1. Collection
  2. List
  3. ArrayList
  4. LinkedList
  5. Vector
  6. Stack
  7. Set
  8. HashSet
  9. LinkedHashSet
  10. TreeSet
  11. Map
  12. HashMap
  13. LinkedHashMap
  14. TreeMap
  15. ConcurrentHashMap
  16. Hashtable

2、 Collection 和 Collections 有什么区别

  1. Collection 是一个集合接口,它提供了对集合对象进行基本操作的通用接口方法,所有集合都是它的子类,比如 List、Set 等。
  2. Collections 是一个包装类,包含了很多静态方法,不能被实例化,就像一个工具类,比如提供的排序方法: Collections. sort(list)。

3、List、Set、Map 之间的区别是什么?

  1. List 和 Set 是存储单列数据的集合,Map 是存储键值对这样的双列数据的集合; List 中存储的数据是有顺序的 ,并且值允许重复;
  2. Map 中存储的数据是无序的 ,它的键是不允许重复的 ,但是值是允许重复的;
  3. Set 中存储的数据是无顺序的,并且不允许不重复的 ,但元素在集合中的位置是由元素的hashcode 决定,即位置是固定的(Set 集合是根据 hashcode 来进行数据存储的,所以位置是固定的,但是这个位置不是用户可以控制的,所以对于用户来说 set 中的元素还是无 序的)

4、 HashMap 和 Hashtable 有什么区别?

  1. 存储:HashMap 运行 key 和 value 为 null,而 Hashtable 不允许。
  2. 线程安全:Hashtable 是线程安全的,而 HashMap 是非线程安全的。
  3. 推荐使用:在 Hashtable 的类注释可以看到,Hashtable 是保留类不建议使 用 ,推 荐 在 单 线 程 环 境下 使 用 HashMap 替 代 ,如 果 需 要 多 线 程使 用 则 用 ConcurrentHashMap 替代。

5、如何决定使用 HashMap 还是 TreeMap?

        对于在 Map 中插入、删除、定位一个元素这类操作,HashMap 是最好的选择,因为相 对而言 HashMap 的插入会更快,但如果你要对一个 key 集合进行有序的遍历,那 TreeMap 是更好的选择。

6、 说一下 HashMap 的实现原理?

        HashMap 基于 Hash 算法实现的,我们通过 put(key,value)存储,get(key)来获取。当传入 key 时,HashMap 会根据 key. hashCode() 计算出 hash 值,根据 hash 值将value 保存在 bucket 里。当计算出的 hash 值相同时,我们称之为 hash 冲突,HashMap 的做法是用链表和红黑树存储相同 hash 值的 value。当 hash 冲突的个数比较少时,使用链表否则使用红黑树。

7、 ArrayList 和 LinkedList 的区别是什么?

  1. 数据结构实现:ArrayList 是动态数组的数据结构实现,而 LinkedList 是双向链表的数据结构实现。
  2. 随机访问效率:ArrayList 比 LinkedList 在随机访问的时候效率要高,因为LinkedList 是线性的数据存储方式,所以需要移动指针从前往后依次查找。
  3. 增加和删除效率:在非首尾的增加和删除操作,LinkedList 要比 ArrayList效率要高,因为ArrayList 增删操作要影响数组内的其他数据的下标。
  4. 综合来说,在需要频繁读取集合中的元素时,更推荐使用ArrayList,而在插入和删除操作较多时,更推荐使用 LinkedList。

8、 如何实现数组和 List 之间的转换?

数组转 List:使用 Arrays. asList(array) 进行转换。 List 转数组:使用 List 自带的 toArray() 方法。

9、 ArrayList 和 Vector 的区别是什么?

  1. 线程安全:Vector 使用了 Synchronized 来实现线程同步,是线程安全的,而 ArrayList 是非线程安全的。
  2. 性能:ArrayList 在性能方面要优于 Vector。
  3. 扩容:ArrayList 和 Vector 都会根据实际的需要动态的调整容量,只不过在Vector 扩容每次会增加 1 倍,而 ArrayList 只会增加 50%。

10、 Array 和 ArrayList 有何区别?

  1. Array 可以存储基本数据类型和对象,ArrayList 只能存储对象。
  2. Array 是指定固定大小的,而 ArrayList 大小是自动扩展的。
  3. Array 内置方法没有 ArrayList 多,比如 addAll、removeAll、iteration 等方法只有 ArrayList 有。

11、 哪些集合类是线程安全的?

Vector、Hashtable、Stack 都是线程安全的,而像 HashMap 则是非线程安全的,不过在 JDK 1.5之后随着 Java. util. concurrent 并发包的出现,它们也有了 自 己 对 应 的 线 程 安 全 类 , 比 如 HashMap 对 应 的 线 程 安 全 类 就 是ConcurrentHashMap。

 12、迭代器 Iterator 是什么?

Iterator 接 口 提 供 遍 历 任 何 Collection 的 接 口 。 我 们 可 以 从 一 个Collection 中使用迭代器方法来获取迭代器实例。迭代器取代了 Java 集合框架中的 Enumeration,迭代器允许调用者在迭代过程中移除元素。

13、 Iterator 怎么使用?有什么特点?

Iterator 的特点是更加安全,因为它可以确保,在当前遍历的集合元素被更改的时候,就会抛出 ConcurrentModificationException 异常。

14、 Iterator 和 ListIterator 有什么区别?

  1. Iterator 可以遍历 Set 和 List 集合,而 ListIterator 只能遍历 List。
  2. Iterator 只能单向遍历,而 ListIterator 可以双向遍历(向前/后遍历)。
  3. ListIterator 从 Iterator 接口继承,然后添加了一些额外的功能,比如添加一个元素、替换一个元素、获取前面或后面元素的索引位置。

15、怎么确保一个集合不能被修改?

可以使用Collections. unmodifiableCollection(Collection c) 方法来创建一个只读集合,这样改变集合的任何操作都会抛出 Java. lang. UnsupportedOperationException异常

标签:容器,面试题,Java,HashMap,Iterator,ArrayList,List,线程,集合
From: https://blog.csdn.net/Hanshy123/article/details/140778734

相关文章

  • 自学JavaScript(放假在家自学第一天)
    目录 JavaScript介绍分为以下几点1.1JavaScript是什么1.2JavaScript书写位置1.3Javascript注释1.4Javascript结束符1.5Javascript输入输出语法JavaScript(是什么?)是一种运行在客户端(浏览器)的编程语言,实现人机交互效果。2.作用(做什么?)网页特效(监听用户的......
  • java多线程(超详细!)
    Java的多线程是一种允许在一个程序中同时运行多个线程的技术。每个线程是独立的执行路径,可以并发执行,从而提高程序的效率和响应能力。1.线程基础Java中的线程可以通过继承Thread类或实现Runnable接口来创建和管理。1.1继承Thread类classMyThreadextendsThr......
  • java多线程(超详细!)
    Java的多线程是一种允许在一个程序中同时运行多个线程的技术。每个线程是独立的执行路径,可以并发执行,从而提高程序的效率和响应能力。1.线程基础Java中的线程可以通过继承Thread类或实现Runnable接口来创建和管理。1.1继承Thread类classMyThreadextendsThread{......
  • 在K8S中,pause容器作用是什么?
    在Kubernetes(K8S)中,pause容器是一个特殊的、由系统提供的最小容器,它被用作Pod网络命名空间中的一个占位符。每个Pod都有一个pause容器,即使用户没有显式地定义它。pause容器的主要作用是确保Pod中的所有其他容器可以共享网络栈。以下是pause容器的一些关键作用:......
  • 在K8S中,在容器内如何获取pod和namespace名字?
    在K8S中,可以通过DownwardAPI将Pod和Namespace的名字注入到容器内的环境变量或文件中。这种方法允许容器内部的应用直接访问这些信息,从而进行相应的配置或处理。具体技术介绍如下:环境变量获取获取Pod名称:在Pod的配置中,可以通过设置一个环境变量,将Pod的名称注入到容器内。例......
  • java
    第一章java概念和开发注意事项java特点Java语言是面向对象的(oop)Java语言是健壮的。java的强类型机制、异常处理、垃圾的自动收集等是Java程序健壮性的重要保证Java语言是跨平台性的[即:一个编译好的.class文件可以在多个系统下运行,这种特性称为跨平台]根本原因是JVM是j......
  • 华为OD笔试机试 - 园区参观路径 (Java 2024年C卷D卷真题算法)
    华为OD机试(C卷+D卷)2024真题目录(Java&c++&python)题目描述园区某部门举办了FamilyDay,邀请员工及其家属参加;将公司园区视为一个矩形,起始园区设置在左上角,终点园区设置在右下角;家属参观园区时,只能向右和向下园区前进,求从起始园区到终点园区会有多少条不同的参观路径......
  • Java计算机毕业设计旅游购票系统(开题报告+源码+论文)
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景随着旅游业的蓬勃发展,游客对于旅游体验的需求日益多样化与便捷化。传统的购票方式,如现场排队购票,不仅耗时耗力,还常常因票源紧张而影响游客的行程安排......
  • 华为OD笔试机试真题算法 - 密码解密 (Java 2024年C卷D卷)
    华为OD机试(C卷+D卷)2024真题目录(Java&c++&python)题目描述给定一段“密文”字符串s,其中字符都是经过“密码本”映射的,现需要将“密文”解密并输出。映射的规则(‘a’~‘i’)分别用(‘1’~‘9’)表示;(‘j’~‘z’)分别用(“10*”~“26*”)表示。约束:映射始终唯一。......
  • Java计算机毕业设计旅游网站设计(开题报告+源码+论文)
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景在全球化与数字化浪潮的推动下,旅游业迎来了前所未有的发展机遇。随着人们生活水平的提高和休闲方式的多样化,旅游需求日益增长,对旅游信息的获取与预订......