基础
- 集合类
 - 并发包
 - IO/NIO
 - JVM,内存模型
 - 泛型
 - 异常
 - 反射
 
问题: ConcurrentHashMap, CopyOnWrite,线程池, CAS, AQS,虚拟机优化
互联网计数相关知识
- mysql
 - redis
 - mongodb
 - nginx
 - tomcat
 - rpc
 - jms
 
对于MySQL,常见的参数设置,存储引擎,还需要了解常见的索引引擎,知道怎么去选择。知道怎么去设计表,怎么优化sql,怎么根据执行计划去调优。高级的你需要去做分库分表的设计和优化,一般互联网企业的数据库都是读写分离,还会垂直与水平拆分,所以这个也有经验的成分在里面。然后redis,mongodb都是需要了解原理,需要会调整参数的,而nginx和tomcat几乎都是JAVA互联网方面必配,其实跟阿里的技术栈选择有点关系。至于rpc相关的就多的去,必须各种网络协议,序列化技术,SOA等等,你要有一个深入的理解。现在应用比较广的rpc框架,在国内就是dubbo了,可以自行搜索。至于jms相关的起码得了解原理吧,一般情况下不是专门开发中间件系统和支撑系统的不需要了解太多细节,国内企业常用的主要是activeMQ和kafka。
编程能力,编程思想,算法能力,架构能力
- 基本排序,查询算法
 - 编程思想,AOP,IOC,设计模式
 - 架构能力, 防重请求设计.
 
