前段时间一直有粉丝问我,有没有去年一些大厂 Java 面试题总结?最新抽时间整理了一些,分享给大家,大家一起共享学习!
一、性能调优系列
1.Tomcat 性能调优
JVM 参数调优: -Xms
2.JVM 性能调优
Java 类加载过程
Java 类加载需要经历一下 7 个过程:
1.加载
加载是类加载的第一个过程,在这个阶段,将完成一下三件事情
(1)通过一个类的全限定名获取该类的二进制流。
(2)将该二进制流中的静态存储结构转化为方法去运行时数据结构。
(3)在内存中生成该类的 Class 对象,作为该类的数据访问入口。
2.验证
验证的目的是为了确保 Class 文件的字节流中的信息不回危害到虚拟机.在该阶段主要完成以下四钟验证:
(1)文件格式验证:验证字节流是否符合 Class 文件的规范,如主次版本号是否在当前虚拟机范围内,常量池中的常量是否有不被支持的类型.
(2)元数据验证:对字节码描述的信息进行语义分析,如这个类是否有父类,是否集成了不被继承的类等。
(3)字节码验证:是整个验证过程中最复杂的一个阶段,通过验证数据流和控制流的分析,确定程序语义是否正确,主要针对方法体的验证。如:方法中的类型转换是否正确,跳转指令是否正确等。
(4)符号引用验证:这个动作在后面的解析过程中发生,主要是为了确保解析动作能正确执行。
3.MySQL 性能调优
复制基本原理流程
1. 主:binlog 线程——记录下所有改变了数据库数据的语句,放进 master 上的 binlog 中;
2. 从:io 线程——在使用 start slave 之后,负责从 master 上拉取 binlog 内容,放进 自己的 relay log 中;
3. 从:sql 执行线程——执行 relay log 中的语句;
MySQL 复制的线程有几个及之间的关联
MySQL 的复制是基于如下 3 个线程的交互( 多线程复制里面应该是 4 类线程):
1. Master 上面的 binlog dump 线程,该线程负责将 master 的 binlogevent 传到 slave;
2. Slave 上面的 IO 线程,该线程负责接收 Master 传过来的 binlog,并写入 relay log;
3. Slave 上面的 SQL 线程,该线程负责读取 relay log 并执行;
4. 如果是多线程复制,无论是 5.6 库级别的假多线程还是 MariaDB 或者 5.7 的真正的多线程复制, SQL 线程只做 coordinator,只负责把 relay log 中的 binlog 读出来然后交给 worker 线程, woker 线程负责具体 binlog event 的执行;