马上进入求职招聘高峰,总结了一份BAT(阿里、百度等)资深Java相关的面试题答案合集给到大家。
该板块的各面试章节,后续会持续迭代更新最新一线互联网公司的面试题目,建议收藏该页面,不定期更新查看~
Java虚拟机(JVM)
- JVM内存模型结构
- 方法区和直接内存什么时候会oom?
- JVM收集器G1的内存模型和CMS的内存模型有什么不同?
- jvm调优用过吗?
- 如何查看java内存使用情况(jconsole、命令jmap、jstack等等)
JVM的面试答案参考:
直通BAT必考题系列:深入剖析JVM之G1收集器、及回收流程、与推荐用例
直通BAT必考题系列:JVM性能调优的6大步骤,及关键调优参数详解
直通BAT必考题系列:7种JVM垃圾收集器特点,优劣势、及使用场景
直通BAT必考题系列:JVM的4种垃圾回收算法、垃圾回收机制与总结
直通BAT必考题系列:深入详解JVM内存模型与JVM参数详细配置
Java必考题目之JVM面试题目和答案
Java集合类与并发容器
- Arraylist、linkedlist差异,应用场景;
- HashMap在JDK1.8有哪些改动?
- HashCurrentMap和HashMap的区别在哪里?
- Hashmap什么时候使用红黑树?
Java集合面试答案参考
高并发编程系列:ConcurrentHashMap的实现原理(JDK1.7和JDK1.8)
阿里P8架构师谈:深入探讨HashMap的底层结构、原理、扩容机制
高并发编程系列:并发容器的原理,7大并发容器详解、及使用场景
Java多线程
- 线程的几种状态,请画出具体的状态流转图?
- Java wait、sleep的区别?
- volatile如何实现指令重排序?
- 线程池中的阻塞队列如果满了怎么办(拒绝策略)?
- Synchronized和AQS异同,AQS公平非公平如何实现;
- 多线程里面对一个整型做加减为啥不能用volatile;
- voliatile和synchonized有什么区别?synchonized和jdk提供的Lock包又有什么区别?
多线程面试答案参考
史上最强多线程面试44题和答案:线程锁+线程池+线程同步等
Java并发编程系列:深入详解Synchronized同步锁的底层实现
最全Java并发编程技能:多线程+线程池+线程锁+并发工具+并发容器
Java并发编程系列:线程的五大状态,以及线程之间的通信与协作
最全Java锁详解:独享锁/共享锁+公平锁/非公平锁+乐观锁/悲观锁
高并发编程系列:CountDownLatch、Semaphore等4大并发工具类详解
并发编程系列:Java线程池的使用方式,核心运行原理、以及注意事项
高并发编程系列:4种常用Java线程锁的特点,性能比较、使用场景
阿里P8架构师谈:线程池的实现原理、优点与风险、以及四种线程池实现
算法
- 二叉树宽度遍历
- 红黑树
- 数据结构的话,链表,树,图的基本知识得懂
- 了解树的先序遍历,中序遍历,后序遍历。图的广度优先搜索算法,深度优先搜索算法。
算法参考
java架构师进阶之独孤九剑:数据结构以及书籍推荐
java架构师进阶之独孤九剑(一)-算法思想与经典算法
java架构师进阶独孤九剑系列(一):数据结构与算法
Spring
- Bean的生命周期;
- 什么是DI、为什么DI、DI的类型(构造器注入、方法注入);
- Spring boot和spring的差别,tomcat如何嵌入spring boot的/spring boot中的tomcat是如何启动的;
- Spring如何解决循环依赖问题;
Spring面试答案参考
史上最全Spring面试71题与答案
阿里P8架构师谈:SpringClound简介,微服务架构,以及与Dubbo的详细比较
数据库
- Join(inner、left、right)的区别?
- Union和union all区别?
- ACID,具体是啥意思?
- 事务隔离级别?
- 幻读和不可重复读的区别?
- Mysql和mongodb有啥区别?
数据库答案参考
高并发架构系列:Redis缓存和MySQL数据一致性方案详解
阿里P8架构师谈:MySQL数据库的索引原理、与慢SQL优化的5大原则
阿里P8架构师谈:MySQL有哪些存储引擎,各自的优缺点,应用场景
阿里P8架构师谈:MySQL行锁、表锁、悲观锁、乐观锁的特点与应用
阿里P8架构师谈:MySQL慢查询优化、索引优化、以及表等优化总结
最全BAT数据库面试89题:mysql、大数据、redis
最全MySQL面试60题和答案
计算机网路
- RPC和http的区别
- 详细描述TCP四次挥手过程
计算机网络参考答案
阿里P8架构师谈:Restful、SOAP、RPC、SOA、微服务之间的区别
阿里P8架构师谈:主流RPC框架详解,以及与SOA、SOAP、REST的区别
Java中间件
- 秒杀项目会使用到哪些中间件?
- 为什么Redis是单线程?
- 如何保证Redis和数据库双写一致?
- 如何设计一个消息队列中间件?
- 分库分表后,id主键如何处理?
- 如何设计一个类似Dubbo的RPC?
Java中间件答案参考
高并发架构系列:如何从0到1设计一个类Dubbo的RPC框架
微服务系列:RPC框架的实现原理,及RPC架构组件详解
阿里P8架构师谈:Restful、SOAP、RPC、SOA、微服务之间的区别
分布式消息系列:详解RocketMQ的架构设计、关键特性、与应用场景
高并发架构系列:Kafka、RocketMQ、RabbitMQ的优劣势比较
如何从0到1设计一个MQ消息队列
高并发架构系列:什么是流量削峰?如何解决秒杀业务的削峰场景
阿里P8架构师谈:双11秒杀系统如何设计?
高并发架构系列:Kafka、RocketMQ、RabbitMQ的优劣势比较
阿里P8架构师谈:消息中间件介绍、典型使用场景、以及使用原则
阿里P8架构师谈:分布式消息Kafka的原理、基础架构、使用场景
阿里P8架构师谈:主流的消息队列MQ比较,详解MQ的4类应用场景