前不久刚从阿里面试回来, 为了这场面试可以说准备了一个半月, 做的准备就是刷题和看视频看书充实自己的技术, 话说是真难啊, 不过还算顺利拿到了 offer, 有很多面试题我已经记不起来了, 这些是当天回家整理好的, 下面我来跟大家一起分享一下.
首先我们需要明白一个事实, 招聘的一个很关键的因素是在给自己找未来的同事, 同级别下要找比自己优秀的人, 面试是一个双向选择的过程, 也是一个将心比心去沟通的过程.
和以前一样, 只有问题没有参考答案, 需要各位小伙伴下来逐一学习!
一, 开场白
简单的介绍一下自己的工作经历与职责, 在校或者工作中主要的工作内容, 主要负责的内容;(你的信息一清二白的写在简历上, 这个主要为了缓解面试者的压力)
介绍下自己最满意的, 有技术亮点的项目或平台, 重点介绍下自己负责那部分的技术细节;(主要考察应聘者对自己做过的事情是否有清晰的描述, 判断做的事情的复杂度)
二, Java 多线程
线程池的原理, 为什么要创建线程池? 创建线程池的方式;
线程的生命周期, 什么时候会出现僵死进程;
说说线程安全问题, 什么实现线程安全, 如何实现线程安全;
创建线程池有哪几个核心参数? 如何合理配置线程池的大小?
volatile,ThreadLocal 的使用场景和原理;
ThreadLocal 什么时候会出现 OOM 的情况? 为什么?
synchronized,volatile 区别, synchronized 锁粒度, 模拟死锁场景, 原子性与可见性;
三, JVM 相关
JVM 内存模型, GC 机制和原理;
GC 分哪两种, Minor GC 和 Full GC 有什么区别? 什么时候会触发 Full GC? 分别采用什么算法?
JVM 里的有几种 classloader, 为什么会有多种?
什么是双亲委派机制? 介绍一些运作过程, 双亲委派模型的好处;
什么情况下我们需要破坏双亲委派模型;
常见的 JVM 调优方法有哪些? 可以具体到调整哪个参数, 调成什么值?
JVM 虚拟机内存划分, 类加载器, 垃圾收集算法, 垃圾收集器, class 文件结构是如何解析的;
四, Java 扩展篇
红黑树的实现原理和应用场景;
NIO 是什么? 适用于何种场景?
Java9 比 Java8 改进了什么;
HashMap 内部的数据结构是什么? 底层是怎么实现的?(还可能会延伸考察 ConcurrentHashMap 与 HashMap,HashTable 等, 考察对技术细节的深入了解程度);
说说反射的用途及实现, 反射是不是很慢, 我们在项目中是否要避免使用反射;
说说自定义注解的场景及实现;
List 和 Map 区别, Arraylist 与 LinkedList 区别, ArrayList 与 Vector 区别;
五, Spring 相关
Spring AOP 的实现原理和场景?
Spring bean 的作用域和生命周期;
Spring Boot 比 Spring 做了哪些改进? Spring 5 比 Spring4 做了哪些改进;
如何自定义一个 Spring Boot Starter?
Spring IoC 是什么? 优点是什么?
SpringMVC, 动态代理, 反射, AOP 原理, 事务隔离级别;
六, 中间件篇
Dubbo 完整的一次调用链路介绍;
Dubbo 支持几种负载均衡策略?
Dubbo Provider 服务提供者要控制执行并发请求上限, 具体怎么做?
Dubbo 启动的时候支持几种配置方式?
了解几种消息中间件产品? 各产品的优缺点介绍;
消息中间件如何保证消息的一致性和如何进行消息的重试机制?
Spring Cloud 熔断机制介绍;
Spring Cloud 对比下 Dubbo, 什么场景下该使用 Spring Cloud?
七, 数据库篇
锁机制介绍: 行锁, 表锁, 排他锁, 共享锁;
乐观锁的业务场景及实现方式;
事务介绍, 分布式事物的理解, 常见的解决方案有哪些, 什么事两阶段提交, 三阶段提交;
MySQL 记录 binlog 的方式主要包括三种模式? 每种模式的优缺点是什么?
MySQL 锁, 悲观锁, 乐观锁, 排它锁, 共享锁, 表级锁, 行级锁;
分布式事务的原理 2 阶段提交, 同步 \ 异步 \ 阻塞 \ 非阻塞;
数据库事务隔离级别, MySQL 默认的隔离级别, Spring 如何实现事务, JDBC 如何实现事务, 嵌套事务实现, 分布式事务实现;
SQL 的整个解析, 执行过程原理, SQL 行转列;
八, Redis
Redis 为什么这么快? Redis 采用多线程会有哪些问题?
Redis 支持哪几种数据结构;
Redis 跳跃表的问题;
Redis 单进程单线程的 Redis 如何能够高并发?
Redis 如何使用 Redis 实现分布式锁?
Redis 分布式锁操作的原子性, Redis 内部是如何实现的?
九, 其他
看过哪些源代码? 然后会根据你说的源码问一些细节的问题?(这里主要考察面试者是否对技术有钻研的精神, 还是只停留在表面, 还是背了几道面经, 这个对于很多有强迫症的面试官, 如果你连源码都没看过, 基本上是会 pass 掉的, 比如我也是这样的!)
项目中遇到了哪些比较有挑战性的问题, 是如何解决的;(这个很有争议, 一方面是你连一个复杂的问题都解决不了, 要你过来干什么, 还有就是我的能力牛逼啊, 但是公司没有业务场景让我展示啊! 这个就看你遇到的面试官了, 祝你好运!)
来源: http://www.jianshu.com/p/e7a2bb76889a