一面面试记录(2月17日)
- 自我介绍
- 接口与抽象类的区别
- 了解过哪些设计模式
- 单例模式的定义
- 工厂模式的用途,为什么需要工厂模式?
- 建造者模式的实现方式
- 在设计模式中更倾向使用抽象类还是接口
- 熟悉哪些 Java 锁
- 死锁的必要条件
- 对 MySQL 索引的理解(那时不会直接表明不会)
- MySQL 事务隔离级别
- 分享使用过的 Java 框架
- 项目中如何使用 git 与 maven
- 编写快速排序算法:快速排序是否稳定,何时会退化,如何优化,时间复杂度
- 编写二分查找算法:复杂度(代码题写得过快,面试官提到时间还没到,接着问了几个问题)
- 对分布式系统的理解(不太了解)
- Java 基础数据类型的说明
- 为什么 int 是 2 的 31 次方
- 对 Docker 的了解
- Java 中的同步与异步概念
反问环节:
- 部门的业务内容
- 对我的评价
二面面试记录(2月18日)
- 进程间通信方式
- 了解的锁的类型
- 介绍 synchronized 和 ReentrantLock
- 说明 ReentrantLock
- 单例模式中变量前的关键字(volatile)
- 单例模式在并发情况下的实现方式
- 双重检查锁(DCL)的概念
- 内部类与枚举类
- volatile 的作用
- 防止 JVM 指令重排,以及保证变量可见性的重要性
- 主动刷新存储的机制
- 聚集索引与非聚集索引的区别
- MySQL 的三大范式,说明一个
- MySQL 的 ACID 特性
- Maven 包冲突的解决方法
- HashMap 的介绍
- HashMap 扩容的理解,扩容因子(loadFactor)
- 红黑树的特点
- 红黑树为何比二叉树更快
- Redis 的高速原因
- Redis 缓存机制
- LeetCode 25 难度:K 个一组反转链表的改版(最后 n 个不足也反转)
三面面试记录(Leader 面试,2月21日,未通过)
- Object 类中的方法
- 对 hashCode() 与 equals() 的理解
- 使用过 Object 类中相关锁的方法吗
- Java 垃圾回收的算法,新生代与老年代的区别
- 设计模式中涉及锁的模式
- 没有使用两个锁时单例会出现什么问题
- 对 MySQL 原理的理解
- 项目开发中遇到的问题及解决方案
- LeetCode 101 简单:对称二叉树(由于题目刷得不够多,未能写到这题,也没多写二叉树,居然用 BFS 实现)