大家好,我是L学长,滴滴秋招已开启,今天给大家分享一位同学上岸滴滴Java后端的面试经验。这位同学背景是双非院校本硕+三段(小中大)公司实习经历。
滴滴面试流程
滴滴的面试流程通常包括三轮技术面试和一轮HR面试。滴滴很喜欢问数据库相关的内容,问的问题涉及很多方向,尤其是MySQL和Redis,基本都是实际生产过程中可能会遇到的一些真实场景问题。
简历投递
进面试第一步就是要把简历(PDF格式)提前准备好,学历是敲门砖,可以这么说学历 > 实习 > 项目,学历属于最底层,双非院校的同学要想逆袭,只能靠实习和其他模块给自己简历增加亮点。通过打磨自己的经历、技能等增加自己的核心竞争力。简历技术点描述精简,不必太多,尽量一页,简洁美观,一目了然。
秋招开放时官网有岗位就投,不要犹豫,不要等准备好了才开始投递,HR也需要筛选,大部分同学都是边投边背知识点然后再约面试,投递时机很重要,这就是找工作所谓的运气>实力的一种原因之一。找工作比的就是获取信息的速度,可以通过各大网站发布的校招信息,避免自己疏漏公司,失去机会。
一面(50min)
基本算是简历面试,(切记简历上真实,询问都知道)简单问问八股文,或者会问点项目和实习经历,不会太深,难度不大。
1. 自我介绍
2. 实习阶段的工作以及实习内容细节(如果没有实习经历的同学要多准备几个项目)
3.项目简单询问(皮毛)
4.Java的基本数据类型及其封装类
①为什么需要封装类?
因为泛型类包括预定义的集合,使用的参数都是对象类型,无法直接使用基本数据类型,所以Java又提供了这些基本类型的封装类。
②基本类型和对应的封装类由于本质有那些区别?
1.基本类型只能按值传递,而封装类按引用传递。
2.基本类型会在栈中创建,而对于对象类型,对象在堆中创建,对象的引用在栈中创建,基本类型由于在栈中,效率会比较高,但是可能存在内存泄漏的问题。
5.Java中操作字符串都有哪些类?它们之间有什么区别?
①String, StringBuffer,StringBuilder.
②String和 StringBuffer、StringBuilder的区别在于String声明的是不可变的对象,每次操作都会生成新的String对象,然后将指针指向新的String对象,而StringBuffer、StringBuilder 可以在原有对象的基础上进行操作,所以在经常改变字符串内容的情况下最好不要使用String。
StringBuffer和StringBuilder最大的区别在于,StringBuffer是线程安全的,而StringBuilder是非线程安全的,但StringBuilder 的性能却高于StringBuffer,所以在单线程环境下推荐使用StringBuilder,多线程环境下推荐使用StringBuffer。
6.为什么要用Redis?
使用缓存的目的就是提升读写性能。而实际业务场景下,更多的是为了提升读性能,带来更好的性能,带来更高的并发量。Redis的读写性能比Mysql好的多,我们就可以把Mysql中的热点数据缓存到Redis中,提升读取性能,同时也减轻了Mysql的读取压力。
7.什么是缓存穿透?如何避免?
缓存穿透:指查询一个一定不存在的数据,如果从存储层查不到数据则不写入缓存,这将导致这个不存在的数据每次请求都要到 DB 去查询,可能导致 DB 挂掉。
解决方案:1.查询返回的数据为空,仍把这个空结果进行缓存,但过期时间会比较短;2.布隆过滤器:将所有可能存在的数据哈希到一个足够大的 bitmap 中,一个一定不存在的数据会被这个 bitmap 拦截掉,从而避免了对 DB 的查询。
8.使用Redis如何设计分布式锁?
基于 Redis 实现的分布式锁,一个严谨的的流程如下:
1、加锁
2、操作共享资源
3、释放锁:Lua 脚本,先 GET 判断锁是否归属自己,再DEL 释放锁
9.Redis持久化方式有哪些?有什么区别?
1、RDB、AOF、混合持久化。
2、RDB的优缺点:
优点:RDB持久化文件,速度比较快,而且存储的是一个二进制文件,传输起来很方便。
缺点:RDB无法保证数据的绝对安全,有时候就是1s也会有很大的数据丢失。
3、AOF的优缺点:
优点:AOF相对RDB更加安全,一般不会有数据的丢失或者很少,官方推荐同时开启AOF和RDB。
缺点:AOF持久化的速度,相对于RDB较慢,存储的是一个文本文件,到了后期文件会比较大,传输困难。
10.类加载机制你怎么理解?
虚拟机把Class文件加载到内存 并对数据进行校验,转换解析和初始化 形成可以虚拟机直接使用的Java类型,即java.lang.Class
11.MySQL 事务隔离级别?
READ UNCOMMITTED(未提交读):事务中的修改,即使没有提交,对其他事务也都是可见 的。会导致脏读。READ COMMITTED(提交读):事务从开始直到提交之前,所做的任何修改对其他事务都是 不可见的。会导致不可重复读。这个隔离级别,也可以叫做“不可重复读”。REPEATABLE READ(可重复读):一个事务按相同的查询条件读取以前检索过的数据,其他事 务插入了满足其查询条件的新数据。产生幻行,会导致幻读。(MySQL 默认隔离级别)SERIALIZABLE(可串行化):强制事务串行执行。
12.手撕算法:单例模式
二面(50min)
二面问涉及面广,问题较杂,需要认真准备
1、 使用 MySQL 的索引应该注意些什么?
2、 SpringBoot和SpringCloud的区别?
SpringBoot专注于快速方便的开发单个个体微服务。SpringCloud是关注全局的微服务协调整理治理框架,它将SpringBoot开发的一个个单体微服务整 合并管理起来, 为各个微服务之间提供,配置管理、服务发现、断路器、路由、微代理、事件总线、全局锁、决策 竞选、分布式会话等等集成服务SpringBoot可以离开SpringCloud独立使用开发项目, 但是SpringCloud离不开SpringBoot ,属于 依赖的关系. SpringBoot专注于快速、方便的开发单个微服务个体,SpringCloud关注全局的服务治理框架。
3、type字段中有哪些常见的值?
4、 说一下 JVM 有哪些垃圾回收器?
如果说垃圾收集算法是内存回收的方法论,那么垃圾收集器就是内存回收的具体实现。下图展示了7种作用于不同分代的收集器,其中用于回收新生代的收集器包括Serial、PraNew、Parallel Scavenge,回收老年代的收集器包括Serial Old、Parallel Old、CMS,还有用于回收整个Java堆的G1收集器。不同收集器之间的连线表示它们可以搭配使用。
5、什么情况下可能会导致Redis阻塞?
数据集中过期
不合理地使用API或数据结构
CPU饱和
持久化阻塞
6、 说一说Redis哈希槽的概念?
slot:称为哈希槽
Redis 集群中内置了 16384 个哈希槽,当需要在 Redis 集群中放置一个 key-value时,redis 先对 key 使用 crc16 算法算出一个结果,然后把结果对 16384 求余数,这样每个 key 都会对应一个编号在 0-16383 之间的哈希槽,redis 会根据节点数量大致均等的将哈希槽映射到不同的节点。
使用哈希槽的好处就在于可以方便的添加或移除节点。
当需要增加节点时,只需要把其他节点的某些哈希槽挪到新节点就可以了;
当需要移除节点时,只需要把移除节点上的哈希槽挪到其他节点就行了。
7、 分布式幂等性如何设计?
具体回答步骤篇幅较长在文档里
8、RabbitMQ中的vhost起什么作用?
虚拟消息服务器,vhost,本质上就是一个mini版的mq服务器,有自己的队列、交换器和绑定,最重要的,自己的权限机制。Vhost提供了逻辑上的分离,可以将众多客户端进行区分,又可以避免队列和交换器的命名冲突。Vhost必须在连接时指定,rabbitmq包含缺省vhost:“/”,通过缺省用户和口令guest进行访问。
rabbitmq里创建用户,必须要被指派给至少一个vhost,并且只能访问被指派内的队列、交换器和绑定。Vhost必须通过rabbitmq的管理控制工具创建。
9、 你平时是怎么处理 Java 异常的
简要回答
10、 场景题 如何做一个热搜榜?
11、 项目内容详细提问
三面(40min)
互联网大厂技术三面很常见,也算是老板面,看重人才的可塑性,考验学习能力,软实力,思维能力,问题难度跟二面差不多。
1、 项目询问 (项目询问比较仔细,需要把自己项目各项细节都熟悉)
2、 redis数据结构是怎么优化内存空间使用的
3、 mysql 给表添加新的列,底层如何做的?
4、 RabbitMQ开启持久化机制,有什么要注意的点?
5、Java的四种引用,强弱软虚
6、 说说Java对象创建过程
7、 你知道哪些JVM性能调优参数?
8、 Spring 事务实现方式
HR面(20min)
大概率就聊天,问学习,岗位意向,大部分时间在闲聊。
面试经验
面试中和面试官交谈需要百分百的自信大方,不要用这个问题应该是这样、我猜是这个问题等不确定的表述,即使你答案正确,也会给面试官你基础很差的印象。
面试通过率很低的同学。能做的就是面试前多准备,面试后多总结,语句自信大方、有逻辑、详略得当的回答问题。建议用总-分-总的方式来回答。
想了解更多互联网公司面经支持一下up主噢~