一.Java基础知识
String、Integer、Long、Enum、BigDecimal、ThreadLocal、ClassLoader、URLClassLoader、ArrayList、 LinkedList。
HashMap、LinkedHashMap、TreeMap、CouncurrentHashMap、HashSet、LinkedHashSet、TreeSet。
Java String的使用。replaceFirst、replaceAll、replace区别,String对“+”的重载,字符串的不可变性。
JDK 6和JDK 7中substring的原理及区别。
自动拆装箱:Integer的缓存机制。
熟悉Java中各种关键字:transient、instanceof、volatile、synchronized、final、static、const 原理及用法。
ArrayList和LinkedList和Vector的区别。List和Vector的区别。
HashMap、HashTable、ConcurrentHashMap区别。apache集合处理工具类的使用。
不同版本的JDK中HashMap的实现的区别以及原因。
枚举:枚举的用法、枚举与单例、Enum类。
Java IO,Java bio、nio和aio的区别、三种IO的用法与原理、netty并学会使用。
Java反射与javassist。反射与工厂模式、 java.lang.reflect.*。
Java序列化:什么是序列化与反序列化、为什么序列化。序列化底层原理。序列化与单例模式。protobuf。为什么说序列化并不安全。
注解:元注解、自定义注解、Java中常用注解使用、注解与反射的结合。
JMS:什么是Java消息服务、JMS消息传送模型。
JMX:java.lang.management.*、 javax.management.*
泛型。泛型与继承。类型擦除。泛型中K T V E。
object等的含义、泛型各种用法。
单元测试:junit、mock、mockito、内存数据库(h2)。
正则表达式:java.lang.util.regex.*
常用的Java工具库:commons.lang, commons.*... guava-libraries netty
什么是API&SPI。
异常:异常类型、正确处理异常、自定义异常。
时间处理:时区、时令、Java中时间API。
编码方式:解决乱码问题、常用编码方式。
语法糖:Java中语法糖原理、解语法糖。
Java 8:lambda表达式、Stream API。
Java 9:Jigsaw、Jshell、Reactive Streams。
Java 10:局部变量类型推断、G1的并行Full GC、ThreadLocal握手机制。
二.Java并发编程
什么是线程,与进程的区别。
Thread、Runnable、Callable、ReentrantLock、ReentrantReadWriteLock、Atomic*、Semaphore、CountDownLatch、、ConcurrentHashMap、Executors。
线程池:自己设计线程池、submit() 和 execute()。
线程安全:死锁、死锁如何排查、Java线程调度、线程安全和内存模型的关系。
锁:CAS、乐观锁与悲观锁、数据库相关锁机制、分布式锁、偏向锁、轻量级锁、重量级锁、monitor、锁优化、锁消除、锁粗化、自旋锁、可重入锁、阻塞锁、死锁。
volatile。happens-before、编译器指令重排和CPU指令重。
synchronized:synchronized是如何实现的?synchronized和lock之间关系。不使用synchronized如何实现一个线程安全的单例。
sleep 和 wait。wait 和 notify。notify 和 notifyAll。ThreadLocal。
写一个死锁的程序。写代码来解决生产者消费者问题。守护线程:守护线程和非守护线程的区别以及用法。原子操作类和CAS;
Lock,Condition和显示锁;
AbstractQueuedSynchronizer分析;
并发工具类和并发容器;
线程池和Executor框架;
实现原理和Java内存模型;
线程安全;
三.JVM
JVM内存结构:堆、栈、方法区、直接内存、堆和栈区别。
Java内存模型:内存可见性、重排序、顺序一致性、volatile、锁、final。
垃圾回收:内存分配策略、垃圾收集器(G1)、GC算法、GC参数、对象存活的判定。
JVM参数及调优。
Java对象模型:oop-klass、对象头。
HotSpot:即时编译器、编译优化。
类加载机制:classLoader、类加载过程、双亲委派(破坏双亲委派)、模块化(jboss modules、osgi、jigsaw)。
虚拟机性能监控与故障处理工具:jps, jstack, jmap、jstat, jconsole, jinfo, jhat, javap, btrace、Tprofiler。
编译与反编译:javac 、javap 、jad 、CRF。
使用工具:VisualVM。
JVM的内存模型分析?
jvm运行时数据区?
jvm性能监控工具?
jvm的堆和栈是如何工作的?
JVM内存管理机制:内存区域与内存溢出异常:运行时数据区域:程序计数器,虚拟机栈,本地方法栈,虚拟机对象;
垃圾收集器与内存分配策略:垃圾回收算法与基础,窜行收集器,并行收集器,内存分配与回收策略;
JVM执行子系统:类文件结构,类加载机制,字节码执行引擎
程序编译与代码优化:编译期优化,运行期优化
字节码、class文件格式
CPU缓存,L1,L2,L3和伪共享
尾递归。位运算。用位运算实现加、减、乘、除、取余。
设计模式:了解23种设计模式。
实现AOP,实现IOC。不用synchronized和lock,实现线程安全的单例模式。nio和reactor设计模式。
网络编程。tcp、udp、http、https等常用协议。三次握手与四次关闭、流量控制和拥塞控制、OSI七层模型、tcp粘包与拆包。
http/1.0 http/1.1 http/2之前的区别。Java RMI,Socket,HttpClient。
cookie 与 session。cookie被禁用,如何实现session。
使用单例、使用Future模式、使用线程池、选择就绪、减少上下文切换、减少锁粒度、数据压缩、结果缓存
线上问题分析:dump获取:线程Dump、内存Dump、gc情况。dump分析:分析死锁、分析内存泄露。
自己编写各种outofmemory,stackoverflow程序:
HeapOutOfMemory、 Young OutOfMemory、MethodArea OutOfMemory、ConstantPool OutOfMemory、DirectMemory OutOfMemory、Stack OutOfMemory Stack OverFlow。
常见问题解决思路:内存溢出、线程死锁、类加载冲突。
使用工具尝试解决以下问题,并写下总结:当一个Java程序响应很慢时如何查找问题、当一个Java程序频繁FullGC时如何解决问题、
如何查看垃圾回收日志、当一个Java应用发生OutOfMemory时该如何解决、如何判断是否出现死锁、如何判断是否存在内存泄露
用Java写一个简单的静态文件的HTTP服务器。实现客户端缓存功能,支持返回304 实现可并发下载一个文件
使用线程池处理客户端请求,使用nio处理客户端请求 支持简单的rewrite规则 上述功能在实现的时候需要满足“开闭原则”。
编译与反编译;Java代码的编译与反编译;Java的反编译工具;词法分析,语法分析(LL算法,递归下降算法,LR算法),语义分析,运行时环境,中间代码,代码生成,代码优化。
四.框架
Servlet线程安全问题。Servlet中的filter和listener。
Hibernate的缓存机制。Hiberate的懒加载。
Spring Bean的初始化。Spring的AOP原理。自己实现Spring的IOC。
Spring MVC。Spring Boot2.0。
Spring Boot的starter原理,自己实现一个starter。
Spring Security
应用服务器:JBoss,tomcat,jetty,Weblogic,Undertow。
Spring 5:响应式编程。
Spring Boot 2.0:性能优化
五.数据库
MySql 执行引擎;MySQL 执行计划;如何查看执行计划,如何根据执行计划进行SQL优化。
事务事务的隔离级别、事务能不能实现锁的功能。
数据库锁:行锁、表锁、使用数据库锁实现乐观锁。
数据库主备搭建,binlog,内存数据库,h2。
常用的nosql数据库:redis、memcached。
分别使用数据库锁、NoSql实现分布式锁。性能调优。
简单的数据结构:栈、队列、链表、数组、哈希表、
树:二叉树、字典树、平衡树、排序树、B树、B+树、R树、多路树、红黑树。
排序算法:各种排序算法和时间复杂度 深度优先和广度优先搜索 全排列、贪心算法、KMP算法、hash算法、海量数据处理。
Solr,Lucene,ElasticSearch。
六.其他
了解nginx和apache服务器的特性并搭建一个对应的服务器。
用Java实现FTP、SMTP协议。
进程间通讯的方式。
什么是CDN?如果实现?什么是DNS?反向代理。
工具:git & svn,maven & gradle。
Linux的常用命令;进程同步;缓冲区溢出;分段和分页;虚拟内存与主存;Zookeeper:基本概念、常见用法。Storm,流式计算,了解Spark,S4。
在linux上部署storm,用zookeeper做协调,运行storm hello world,local和remote模式运行调试storm topology。
Hadoop,离线计算HDFS、MapReduce。
分布式日志收集flume,kafka,logstash。
数据挖掘,mahout。什么是XSS:XSS的防御。
什么是CSRF。什么是注入攻击。SQL注入、XML注入、CRLF注入。
什么是文件上传漏洞。
加密与解密。MD5,SHA1、DES、AES、RSA、DSA。
什么是DOS攻击和DDOS攻击。
memcached为什么可以导致DDos攻击、什么是反射型DDoS。
SSL、TLS,HTTPS。
如何通过Hash碰撞进行DOS攻击。
用openssl签一个证书部署到apache或nginx。
数据一致性、服务治理、服务降级。
分布式事务:2PC、3PC、CAP、BASE、 可靠消息最终一致性、最大努力通知、TCC。
Dubbo:服务注册、服务发现,服务治理。
分布式数据库:怎样打造一个分布式数据库、什么时候需要分布式数据库、mycat、otter、HBase。
分布式文件系统:mfs、fastdfs。
分布式缓存:缓存一致性、缓存命中率、缓存冗余。
SOA、康威定律。
ServiceMesh。
Docker & Kubernets
CDN技术
监控什么:CPU、内存、磁盘I/O、网络I/O等。
监控手段:进程监控、语义监控、机器资源监控、数据波动。监控数据采集。日志、埋点。
Dapper。
负载均衡。tomcat负载均衡、Nginx负载均衡。
DNS:DNS原理、DNS的设计。
扩展篇云计算:IaaS、SaaS、PaaS、虚拟化技术、openstack、Serverlsess。
搜索引擎:Solr、Lucene、Nutch、Elasticsearch。
权限管理:Shiro。
哈希算法、Merkle树、公钥密码算法、共识算法、Raft协议、Paxos 算法与 Raft 算法、拜占庭问题与算法、消息认证码与数字签名。
比特币:挖矿、共识机制、闪电网络、侧链、热点问题、分叉。
以太坊,超级账本,人工智能。
数学基础、机器学习、人工神经网络、深度学习、应用场景。
常用框架:TensorFlow、DeepLearning4J
其他语言:Groovy、Python、Go、NodeJs、Swift、Rust,groovy,cassandra,Protobuf,WebWork
了解Hadoop+Zookeeper+Flume+Hive+HDFS大数据离线数据分析,能够实现网站的pv,uv,vv,br等数据监控分析,并且也了解Storm+Kafka的实时数据分析。
Spark MLlib
SonarQube
DCDB技术;
任务调度技术;
elog技术;
eMonitor技术;(监控系统)
epaas技术;(容器云)
MySQL延迟问题和数据刷盘策略
CQRS