一、网络原理
- OSI 与 TCP/IP 各层的结构与功能,都有哪些协议
- TCP 建立连接的过程,为什么要三次握手?
- TCP、UDP 协议的区别,各自的应用场景
- 打开浏览器,输入 URL 地址,访问主页的过程
- HTTP 有哪些方法?
- HTTP 和 HTTPS 有什么区别?
二、Java 核心技术
- HashMap 底层数据结构是什么,时间复杂度多少?
- JDK 8 中对 HashMap 做了怎样的优化?
- HashMap 和 TreeMap 什么区别?
- ConcurrentHashMap 的实现原理
- 包装类的缓存机制如何应用
- Error 和 Exception 有什么区别?
- 通过一个例子描述下 BIO、NIO、AIO 三者的区别?
- 动态代理实现有几种方式?
- 阐述 JDBC 操作数据库的步骤?
- Lambda 表达式有哪些应用?
三、Java 并发编程
- 线程有哪几种状态?
- 创建线程池需要指定什么参数?
- 线程池底层如何实现,工作原理怎样?
- volatile 的实现原理是什么?
- Synchronized 和 Lock 什么区别?
- Java 中有哪些锁?有什么区别?
- Synchronized 锁升级的原理是什么?
- 使用 ThreadLocal 有哪些注意事项?
- CAS 如何实现的?
- Thread 类的 sleep() 方法和对象的 wait() 方法都可以让线程暂停执行,它们有什么区别?
- 守护线程是什么?
- 说一下 Atomic 的原理?
- 如何用 Java 实现生产者消费者?
- Java 内存模型是什么?
- JMM 在并发中有什么应用?
四、Java 虚拟机
- 描述一下 JVM 的内存结构?
- Java 8 的内存分化有哪些改进?
- 有哪些对象分配规则?
- Java 对象创建过程
- 描述 JVM 加载 class 文件的机制?
- 双亲委派模型是什么?
- 字节码是什么?字节码增强有哪些?
- JVM 有哪些编译优化?
- 常见的垃圾回收算法和收集器有哪些?
- 如何打印虚拟机堆栈信息?
五、Spring 系列
- 什么是 AOP,AOP 的作用是什么?
- 如何理解 Spring 的 IOC 和 DI?
- CGLIB 和 JDK 动态代理什么区别?
- Spring Boot 支持哪些嵌入式容器,如何配置?
六、数据库
- MySQL 中 MyISAM 与 InnoDB 引擎的区别
- MySQL InnoDB 的默认隔离级别是什么?
- 举一个数据库死锁的例子,MySQL 怎么解决死锁?
- MySQL InnoDB 存储的文件结构,为什么使用 B-Tree(B+Tree)?
- 索引的类型有哪些?
- 如何创建合理的索引,索引如何优化?
- 索引失效有哪几种情况?
- …
七、分库分表
- 为什么要分库分表?
- 如何解决分库分表主键问题?
- 分库分表有哪些中间件,有什么优点和缺点?
- …
八、分布式缓存
- 怎么保证缓存与数据库的双写一致性
- Redis 新版本支持多线程,性能怎么样?
- Redis 有什么数据类型,都在哪些场景下使用?
- Redis 的高可用有哪些机制?
- Redis 的持久化有哪些方式?
- Redis 过期策略都有哪些?
- 写一下 Java 版本的 LRU 代码?
九、分布式服务框架
- Dubbo 的架构和服务调用过程怎样?
- 注册中心挂了可以继续通信吗?
- ZooKeeper 的原理是什么?
- Dubbo 支持哪些序列化协议?
十、分布式消息队列
- 消息队列有什么作用?
- 如何保证消息队列的高可用?
- 如何保证消息不被重复消费?
- 不同消息队列的选型和对比
十一、分布式系统
- CAP 理论是什么?
- Base 理论是什么?
- 数据一致性有哪几种?
- 分布式事务有哪些解决方案?
- 如何使用 Redis 实现分布式锁?
- 负载均衡有哪些常见策略?