后端面试题及详细答案.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

后端面试题及详细答案

一、Java基础相关

1.说说HashMap的底层实现原理(JDK1.8及之后)

答案:JDK1.8之后的HashMap底层是“数组+链表+红黑树”的组合结构,核心是通过哈希表实现键值对的快速存取。

具体实现:

(1)存储结构:数组(Node[]table)是核心载体,每个数组元素是一个Node节点(包含key、value、next指针和hash值)。当多个key的哈希值计算后落到同一个数组索引时,会形成链表;当链表长度超过阈值(默认8),且数组长度大于等于64时,链表会转化为红黑树,以提升查询效率(红黑树查询时间复杂度O(logn),链表是O(n))。

(2)哈希计算:先通过key的hashCode()方法得到原始哈希值,再通过HashMap的hash()方法进行二次哈希(将原始哈希值的高16位与低16位异或),目的是减少哈希冲突,让哈希值分布更均匀。

(3)索引计算:通过二次哈希后的hash值与数组长度-1进行按位与运算,得到key对应的数组索引(等价于取模运算,但按位与效率更高,前提是数组长度必须是2的幂次方)。

(4)扩容机制:当HashMap的元素个数(size)超过负载因子(默认0.75)乘以数组长度时,会触发扩容。扩容后的数组长度是原来的2倍(保证是2的幂次方),然后将原数组中的元素重新计算索引并迁移到新数组中(红黑树迁移时可能会退化为链表)。

补充:HashMap线程不安全,在并发场景下可能出现链表环化(JDK1.7及之前)、数据丢失等问题,并发场景可使用ConcurrentHashMap替代。

2.谈谈Java中的线程安全问题,以及如何保证线程安全

答案:线程安全问题本质是多个线程同时操作共享资源时,由于指令重排序、内存可见性、原子性问题,导致程序运行结果与预期不一致的问题。

核心问题拆解:

(1)原子性:一个操作或多个操作的集合,要么全部执行且执行过程中不被中断,要么全部不执行(比如i++,实际是i=load、i=add、i=store三个指令,多线程下可能被中断,导致结果错误)。

(2)内存可见性:多个线程操作共享变量时,一个线程修改了变量的值,其他线程能立即看到修改后的值(默认情况下,线程会将共享变量缓存到本地内存,修改后不会立即同步到主内存,导致其他线程看不到)。

(3)有序性:程序执行的顺序按照代码的先后顺序执行(JVM为了优化性能,可能会对指令进行重排序,单线程下不影响结果,但多线程下可能导致逻辑错误)。

保证线程安全的方案:

(1)使用同步关键字:synchronized(悲观锁),可修饰方法或代码块,保证同一时间只有一个线程执行同步代码。底层通过对象头的监视器锁(monitor)实现,JDK1.6对synchronized进行了优化,引入偏向锁、轻量级锁、重量级锁的升级机制,减少性能开销。

(2)使用JUC并发工具:

-Lock接口:ReentrantLock(可重入锁)、ReadWriteLock(读写锁)等,相比synchronized更灵活,支持公平锁/非公平锁、可中断锁、超时锁等。

-原子类:AtomicInteger、AtomicReference等,基于CAS(CompareandSwap,比较并交换)实现原子操作,无锁机制,性能优于synchronized。

-并发集合:ConcurrentHashMap、CopyOnWriteArrayList等,专门为并发场景设计,避免了普通集合的线程安全问题。

(3)volatile关键字:保证内存可见性和有序性,但不保证原子性。适用于变量被多个线程读取、单个线程修改的场景(比如作为状态标记位)。

(4)线程封闭:将共享资源限制在单个线程内使用(比如局部变量),避免多线程共享,自然不会出现线程安全问题。

二、Spring相关

1.说说SpringBean的生命周期

答案:SpringBean的生命周期是从Bean实例化(创建对象)开始,到Bean销毁(释放资源)结束的全过程,核心可分为5个阶段,具体步骤如下:

(1)实例化(Instantiation):Spring通过反射机制调用Bean的无参构造方法,创建Bean的实例对象(此时对象仅初始化了成员变量的默认值,未赋值)。

(2)属性赋值(Populate):Spring根据配置信息(XML、注解等),为Bean的成员变量赋值(依赖注入)。如果属性是其他Bean,会先初始化依赖的Bean。

(3)初始化(Initialization):

-执行Aware接口方法:如果Bean实现了Aware系列接口(如BeanNameAware、BeanFactoryAware、ApplicationContextAware),Spring会调用对应的方法,

文档评论(0)

151****9429 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档