整理了18家大厂Java面试题共350道(分布式+微服务+高并发)

前段时间一直有粉丝问我,有没有今年一些大厂Java面试题总结?最新抽时间整理了一些,分享给大家,大家一起共享学习!

一、性能调优系列

1.Comcat性能调优

JVM参数调优: -Xms<size> 表示JVM初始化堆的大小,一Xmx<size>表示JVM堆的最大值。这两个值的大小一般根据需要进行设置。当应用程序需要的内存超出堆的最大值时虚拟机就会提示内存溢出,并且导致应用服务崩溃。因此- -般建议堆的最大值设置为可用内存的最大值的80%。在catalina.bat中,设置JAVA _0PTS='-Xms256m-Xmx512m',表示初始化内存为256MB,可以使用的最大内存512MB。

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 的执行;

二、微服务系列

什么是 Spring Cloudÿ

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值