- ThreadLocal的原理和用法
- ThreadPool的用法和示例
- wait()和sleep()的区别
Java高阶
- Java虚拟机,Java运行,Java GC机制(可达性分析法,引用计数法)
- Java对象的完整生命周期
- JVM内存模型
- 进程间通信,线程间通信
- JVM类加载机制
- Java引用类型
- 设计模式:除常用设计模式之外,特别的,反射机制,代理模式
- HTTP协议和HTTPS协议
- Socket协议,Socket实现长连接
- TCP和UDP协议
- HTTP协议中GET和POST的具体实现
- 序列化和反序列化
- 线程池的实现原理
- 数据库基础知识:多表查询、索引、数据库事务
数据结构及算法
数据结构
- 栈和队列
- 数组和链表,自定义一个动态数组
- Hash表,及Hash冲突的解决
- 二叉树
- B+ B-树
- 基础排序算法:重点 快排、归并排序、堆排序(大根堆、小根堆)
- 快排的优化
- 二分查找与变种二分查找
- 哈夫曼树、红黑树
- 字符串操作,字符串查找,KMP算法
- 图的BFS、DFS、prim、Dijkstra算法(高阶技能)
- 经典问题:海量数据的处理 (10亿个数中找出最大的10000个数 TOP K问题&#x