java类加载过程
类加载过程:加载、验证、准备、解析、初始化。
类加载过程中主要是将Class文件(类的二进制字节流)加载到虚拟机内存中,真正执行字节码的操作,在加载完成后才真正开始。
类加载器:双亲委派模型
双亲委派的好处 : 由于每个类加载都会经过最顶层的启动类加载器,比如 java.lang.Object这样的类在各个类加载器下都是同一个类(只有当两个类是由同一个类加载器加载的才有意义,这两个类才相等)。如果没有双亲委派模型,由各个类加载器自行加载的话。当用户自己编写了一个 java.lang.Object类,那样系统中就会出现多个 Object,这样 Java 程序中最基本的行为都无法保证,程序会变的非常混乱。
https://blog.csdn.net/ns_code/article/details/17881581数据库索引的实现原理
索引的实现通常使用B树及其变种B+树。
https://blog.csdn.net/suifeng3051/article/details/52669644b树和b+树的区别
https://blog.csdn.net/zhuanzhe117/article/details/78039692-
java.util.concurrent包下的类
红黑树和TreeMap
https://www.cnblogs.com/Java3y/p/8808818.html多态的实现原理
https://blog.csdn.net/SEU_Calvin/article/details/52191321生产者消费者手写
http://www.importnew.com/27063.htmlHashMap,HashTable,ConcurrentHashmap区别,底层源码
https://crossoverjie.top/2018/07/23/java-senior/ConcurrentHashMap/mysql的引擎以及区别
(1)两种类型最主要的差别就是Innodb 支持事务处理与外键和行级锁。而MyISAM不支持。
(2)MyISAM拥有较高的插入、查询速度,但不支持事务。
(3)MyISAM的索引和数据是分开的,并且索引是有压缩的,内存使用率就对应提高了不少。Innodb是索引和数据是紧密捆绑的。数据库的三大范式
第一范式(1NF):原子性 字段不可再分,否则就不是关系数据库;
第二范式(2NF):唯一性 一个表只说明一个事物;
第三范式(3NF):每列都与主键有直接关系,不存在传递依赖;
https://www.cnblogs.com/linjiqin/archive/2012/04/01/2428695.htmlSpringMVC处理流程
https://www.jianshu.com/p/8a20c547e245Mybatis配置文件
https://blog.csdn.net/xuchuangqi/article/details/52576648
https://segmentfault.com/a/1190000012833571#articleHeader0Mybatis防止SQL注入
https://www.cnblogs.com/200911/p/5869097.html线程池参数
https://blog.csdn.net/zhouhl_cn/article/details/7392607JDK、JRE、JVM区别与联系
https://blog.csdn.net/ancientear/article/details/79483592线程池使用及底层实现机制详解
https://blog.csdn.net/zhangliangzi/article/details/52389766IOC AOP实现原理
Cookie和Session
https://www.zhihu.com/question/19786827Servlet 的生命周期
https://www.jianshu.com/p/1d5089a635afMysql索引失效的情况
https://blog.csdn.net/sc9018181134/article/details/78888022Spring框架中的设计模式
http://blog.didispace.com/spring-design-partern/消息队列常见问题和解决方案
https://blog.csdn.net/qq_36236890/article/details/81174504Redis过期策略 实现原理
https://blog.csdn.net/xiangnan129/article/details/54928672
Java基础:
hashmap:构成原理,扩容过程,put过程,为什么长度总是2的N次方,是否线程安全;
list,set,queue;
一些关键词的作用:final,static等等;
多线程:sychronized,Lock,volatile,CAS。每一个的实现原理和常用场景,可重入锁和公平锁的原理,jdk的锁优化;
线程池:常用的参数,工作过程;
Spring:ioc和aop的实现原理,jdk动态代理和cglib的区别;
单例模式,工厂模式,代理模式等等手写;
Object类中的常用方法:equla,hashcode,wait,notify等等,经常被问,尤其是hashcode的重写,hashcode在容器中的运用;
装箱和拆箱;
异常和error;
jvm:类加载机制,垃圾回收策略,垃圾回收算法的好处,常见的调优方式。
数据库:
基本的写sql能力:灵活使用join,groupby,order by以及常见的聚合函数;
索引的原理:b+树的好处,b+树和b树的区别;
联合索引的设计:比如(A,B,C)索引,在where a=1,b>1,c=1中哪些列可以用到索引?where b=1,c=1可不可以用到索引,为什么(联合索引的结构)?where a=1,c=1时可不可以用到索引?where a=1,b=1 order by c可不可以用到?
索引设计:根据一些常用的查询条件设计索引;
MVCC;
事务相应的隔离级别,默认的隔离级别;
redis:
redis的模型,redis为什么快?redis为什么是单线程的?多核心机器如何部署redis(单进程占用单核)?
epoll,poll和select;
redis,mysql***作的时间数量级;
redis各种集群的方式,哨兵模式;
redis持久化的方式,aof文件太大了怎么办,主从同步的方式;
redis的五种常用数据结构,以及对应的底层数据结构的实现(zpilist,skiplist,quicklist,sds等等要有些了解);
消息队列:
常用的消息队列设计和适用的各种场景;
kafka的原理,kafka作为消息队列和redis的区别;
一个topic中的partition是不是一定散布在同一个broker中?
如果要保证消息全局有序,怎么做?
leader选举是怎么选的?
kafka中consumer怎么保持状态的?
kafka是哪个公司出的?(还真老有人问)
网络:
tcp的各种东西,udp和tcp的区别和常用场景;
http的各种状态码,以及相应的排查错误的方式;
http请求头等;
老生常谈的输入url按下回车的全过程;
操作系统:
经常问的就是linux指令,死锁的各种问题,虚拟内存