这部分面试题多用于面试的热身运动,对很多找实习和准备毕业找工作的小伙伴至关重要。
HashMap与ConcurrentHashMap
-
都是key-value 形式的存储数据;
-
HashMap 是线程不安全的,ConcurrentHashMap 是JUC 下的线程安全的;
-
HashMap 底层数据结构是数组+ 链表(JDK 1.8 之前)。JDK 1.8 之后是数组+ 链表+ 红 黑 树。当链表中元素个数达到8 的时候,链表的查询速度不如红黑树快,链表会转为红黑树, 红黑树查询速度快;
-
HashMap 初始数组大小为16(默认),当出现扩容的时候,以0.75 *数组大小的方式进行 扩容;
-
ConcurrentHashMap 在JDK 1.8 之前是采用分段锁来实现的Segment + HashEntry , Segment 数组大小默认是16 ,2 的n 次方;JDK 1.8 之后,采用Node + CAS + Synchronized 来保证并发安全进行实现。
进程,线程和虚拟线程
-
进程是是操作系统进行资源分配和调度的一个独立单位。系统运行一个程序即一个进程从创建,运行到消亡的过程。简单来说,一个进程就是一个执行中的程序,它在计算机中一个指令接着一个指令地执行着,同时,每个进程还占有某些系统资源如CPU 时间,内存空间,文件,输入输出设备的使用权等等。换句话说,当程序在执行时,将会被操作系统载入内存中
-
线程与进程相似,但线程是一个比进程更小的执行单位。一个进程在其执行的过程中可以产生多个线程。与进程不同的是同类的多个线程共享同一块内存空间和一组系统资源,所以系统在产生一个线程,或是在各个线程之间做切换工作时,负担要比进程小得多,也正因为如此,线程也被称为轻量级进程。
-
在Java 21中,JDK引入了虚拟线程(Virtual Threads),也称为“用户模式线程(user-mode threads)”或“纤程(fibers)”。该功能旨在简化并发编程并提供更好的可扩展性。虚拟线程是轻量级的,这意味着它们可以比传统线程创建更多数量,并且开销要少得多。这使得在自己的线程中运行单独任务或请求变得更加实用,即使在高吞吐量的程序中也是如此。
往期文章
金三银四面试题(十四):Java基础问题(5)2024-04-04
金三银四面试题(十三):Java基础问题(4)2024-04-03
金三银四面试题(十二):Java基础问题(3)2024-04-02
金三银四面试题(十一):Java基础问题(2)2024-04-01
金三银四面试题(十):Java基础问题(1)2024-03-31
金三银四面试题(九):JVM常见面试题(3)2024-03-30
金三银四面试题(八):JVM常见面试题(2)2024-03-30
金三银四面试题(七):JVM常见面试题(1)2024-03-28
金三银四面试题(六):对象大小知多少2024-03-27
金三银四面试题(五):JVM之TLAB2024-03-26