二面蚂蚁金服暴毙,错失offer面试总结,面试真题+解析分享下

前言

从春节回家开始,因为疫情的原因就一直在家里待的,足不出户,自己的公司也是因为这个原因,工资都没发,一直拖得,说等复工才发,我自己琢磨这样也不是个事啊,尤其是看网上今天这个公司破产那个公司破产的,多少人失业什么的,我知道我们这种小公司是没有保障的,想的疫情过后去大厂阿里,京东,滴滴,美团等,看着自己收集的资料太多有点无从下手,就主要看了下阿里的技术面,自己总结恶补了下,一直啃面经啃到可以复工,向阿里投递了简历(自己公司因为拖欠工资,所以想的辞职了)想的我这短时间的恶补,怎么也可以到四五面吧,没想的,栽倒了在二面上还是很可惜,好了,分享自己的面试题与复习笔记

1.蚂蚁金服面试官问的Spring Boot问题

什么是 Spring Boot?

为什么要用 Spring Boot?

Spring Boot 的核心配置文件有哪几个?它们的区别是什么?

Spring Boot 的配置文件有哪几种格式?它们有什么区别?

Spring Boot 的核心注解是哪个?它主要由哪几个注解组成的?

开启 Spring Boot 特性有哪几种方式?

Spring Boot 需要独立的容器运行吗?

运行 Spring Boot 有哪几种方式?

Spring Boot 自动配置原理是什么?

Spring Boot 的目录结构是怎样的?

1.1我的Spring Boot学习笔记

Spring Boot、Spring MVC 和 Spring 有什么区别?

什么是自动配置?

什么是 Spring Boot Stater ?

你能否举一个例子来解释更多 Staters 的内容?

Spring Boot 还提供了其它的哪些 Starter Project Options?

Spring 是如何快速创建产品就绪应用程序的?

创建一个 Spring Boot Project 的最简单的方法是什么?

Spring Initializr 是创建 Spring Boot Projects 的唯一

为什么我们需要 spring-boot-maven-plugin?

如何使用 SpringBoot 自动重装我的应用程序?

什么是嵌入式服务器?我们为什么要使用嵌入式服务器呢?

如何在 Spring Boot 中添加通用的 JS 代码?

2.蚂蚁金服面试官问的RabbitMQ问题

使用RabbitMQ有什么好处?

RabbitMQ 中的 broker 是指什么?cluster 又是指什么?

RabbitMQ 概念里的 channel、exchange 和 queue 是逻辑概念,还是对应着进程实体?分别起什么作用?

vhost 是什么?起什么作用?

消息基于什么传输?

消息如何分发?

消息怎么路由?

什么是元数据?元数据分为哪些类型?包括哪些内容?与 cluster 相关的元数据有哪些?元数据是如何保存的?元数据在 cluster 中是如何分布的?

2.1我的RabbitMQ学习笔记

什么是rabbitmq

为什么要使用rabbitmq

使用rabbitmq的场景

如何确保消息正确地发送至RabbitMQ? 如何确保消息接收方消费了消息?

如何避免消息重复投递或重复消费?

消息基于什么传输?

消息如何分发?

消息怎么路由?

如何确保消息不丢失?

使用RabbitMQ有什么好处?

rabbitmq的集群

mq的缺点

3.蚂蚁金服面试官问的MySQL问题

事务四大特性

MySQL的事务隔离级别

数据库的索引

数据库三范式

脏读&不可重复读&幻读

存储引擎 MyISAM和InnoDB区别

Mysql中有哪几种锁?

讲一下存储过程

3.1我的MySQL灵魂拷问笔记

Mysql的技术特点是什么?

Heap表是什么?

Mysql服务器默认端口是什么?

与Oracle相比,Mysql有什么优势?

如何区分FLOAT和DOUBLE?

如何获取当前的Mysql版本?

Mysql中使用什么存储引擎?

Mysql驱动程序是什么?

主键和候选键有什么区别?

如何使用Unix shell登录Mysql?

你怎么看到为表格定义的所有索引?

InnoDB是什么?

4.蚂蚁金服面试官问的设计模式问题

请列举出在JDK中几个常用的设计模式?

什么是设计模式?你是否在你的代码里面使用过任何设计模式?

Java 中什么叫单例设计模式?请用Java 写出线程安全的单例模式

在 Java 中,什么叫观察者设计模式(observer design pattern)?

使用工厂模式最主要的好处是什么?在哪里使用?

举一个用 Java 实现的装饰模式(decorator design pattern)?它是作用于对象层次还是类层次?

在 Java 中,为什么不允许从静态方法中访问非静态变量?

例说明什么情况下会更倾向于使用抽象类而不是接口?

4.1 23种设计模式知识要点

单例模式

工厂模式

抽象工厂模式

模板方法模式

建造者模式

代理模式

原型模式

中介者模式

命令模式

责任链模式

5.蚂蚁金服面试官问的并发编程问题

Java中有几种方法可以实现一个线程?

如何停止一个正在运行的线程?

什么是Daemon线程?它有什么意义?

ava如何实现多线程之间的通讯和协作?

乐观锁和悲观锁的理解及如何实现,有哪些实现方式?

什么是可重入锁(ReentrantLock)?

什么叫线程安全?servlet是线程安全吗?

同步有几种实现方法?

5.1并发编程面试专题

Java中守护线程和本地线程区别

什么是多线程中的上下文切换

死锁与活锁的区别,死锁与饥饿的区别

线程与进程的区别

Java中用到的线程调度算法是什么

什么是线程组,为什么在Java中不推荐使用

在Java中Executor和Executors的区别

什么是原子操作,在Java Concurrency API中有哪些原子类(atomic classes)

什么是Executors框架

什么是阻塞队列,阻塞队列的实现原理是什么,如何使用阻塞队列来实现生产者-消费者模型

6.蚂蚁金服面试官问的JVM虚拟机问题

什么是Java虚拟机?为什么Java被称作是“平台无关的编程语言”?

什么是类的加载

描述一下JVM加载class文件的原理机制?

如何判断对象可以被回收?

什么时候一个对象会被GC?

为什么要在这种时候对象才会被GC?

JVM内存分为哪几部分,这些部分分别都存储哪些数据?

一个对象从创建到销毁都是怎么在这些部分里存活和转移的?

6.1JVM虚拟机面试专题

Java 类加载过程?

描述一下 JVM 加载 Class 文件的原理机制?

Java 内存分配。

GC 是什么? 为什么要有 GC?

简述 Java 垃圾回收机制。

如何判断一个对象是否存活?(或者 GC 对象的判定方法)

垃圾回收的优点和原理。并考虑 2 种回收机制。

垃圾回收器的基本原理是什么?垃圾回收器可以马上回收内存吗?有什么办法主动通知虚拟机进行垃圾回收?

Java 中会存在内存泄漏吗,请简单描述。

深拷贝和浅拷贝

7.蚂蚁金服面试官问的Redis问题

什么是Redis?简述它的优缺点?

Redis相比memcached有哪些优势?

Redis支持哪几种数据类型?

Redis主要消耗什么物理资源?

Redis的全称是什么?

Redis有哪几种数据淘汰策略?

Redis官方为什么不提供Windows版本?

Redis集群方案应该怎么做?都有哪些方案?

为什么Redis需要把所有数据放到内存中?

Redis有哪些适合的场景?

7.1 Redis面试专题

为什么要用 redis /为什么要用缓存

为什么要用 redis 而不用 map/guava 做缓存?

redis 和 memcached 的区别

redis 常见数据结构以及使用场景分析

redis 设置过期时间

redis 内存淘汰机制(MySQL里有2000w数据,Redis中只存20w的数据,如何保证Redis中的数据都是热点数据?)

redis 持久化机制(怎么保证 redis 挂掉之后再重启数据可以进行恢复)

redis 事务

Redis 常见异常及解决方案

分布式环境下常见的应用场景

8. 我的参考学习资料:Java核心知识点整理

转发+关注!私信我“资料”即可免费获取以下我收集整理的全部学习资料!!!

JVM,集合,HTTP网络,多线程并发,JAVA基础,Spring,微服务,Zookeeper,Kafka,RabbitMQ,Hbase,消息中间件,MongoDB,设计模式,负载均衡,数据库,一致性哈希,算法,数据结构,加密算法,分布式缓存,Netty,Linux,Tomcat,Nginx,Redis等

9. 各类学习书籍整理

10. 各类面试题整理